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I.  INTRODUCTION 

A.  DC  ZONAL  ELECTRICAL  DISTRIBUTION  SYSTEM 

Improvements  in  semiconductor  technology  have  sparked  a  power  electronics 
revolution.  In  order  to  best  take  advantage  of  these  improvements,  a  new  architecture  for 
shipboard  power  distribution  has  been  proposed  called  the  DC  Zonal  Electrical 
Distribution  System  (DC  ZEDS)  [Ref.  1].  In  this  new  distribution  proposal,  the  main 
busses  are  DC  with  desired  levels  being  1000  V  and  above.  The  ship  is  divided  into 
zones,  and  each  zone  contains  two  common  energy  conversion  devices  which  are  fed 
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Figure  1-1  -  Integrated  Power  System  (from  [Ref.  2]) 


from  the  DC  busses.  As  shown  in  Figure  1-1,  there  are  at  least  two  DC  busses,  a  port  bus 
and  a  starboard  bus.  The  DC  is  distributed  from  the  source(s)  into  the  separate  zones 
[Ref.  2].  Each  zone  contains  a  number  of  Ship  Service  Converter  Modules  (SSCM)  and 
Inverter  Modules  (SSIM).  Each  zone  has  two  primary  SSCMs  which  are  used  to  step- 
down  the  main  DC  bus  voltage  to  a  regulated  level  for  use  in  the  zone.  In  this  way  the 
SSCM  not  only  acts  as  a  preregulator  but  also  acts  as  a  buffer  and  implements  fault 
protection  for  each  zone.  Electric  loads  within  the  zone  are  fed  by  either  SSCMs  or 
SSIMs  depending  on  the  load's  requirement  for  DC  or  AC  power. 

B.  RESEARCH  FOCUS 

The  focus  of  this  thesis  is  on  controlling  the  SSCM  and  SSIM  using  the  Universal 
Controller.  Both  the  SSCM  and  SSIM  are  particular  examples  of  Power  Electronic 
Building  Blocks  (PEBBs)  or  devices  that  integrate  power  conversion,  sensing  and  control 
into  one  package.  The  Universal  Controller,  designed  by  the  engineers  at  the  Naval 
Surface  Warfare  Center  (NS WC)  in  Annapolis,  Maryland,  is  a  digital  controller  built  to 
demonstrate  the  Power  Electronic  Building  Blocks  (PEBB)  software  control  capability 
[Ref.  3].  The  main  advantage  of  using  a  digital  controller  in  a  program  like  PEBB  is  that 
control  algorithm  configuration  changes  can  be  made  in  the  software  and  do  not  need  to 
be  re-engineered  into  the  hardware.  For  example,  to  change  the  switching  frequency  of 
the  SSCM  that  uses  an  analog  controller  one  must  physically  change  various  components 
on  the  control  board.  To  affect  the  same  change  with  a  digital  controller,  one  must  only 
implement  a  change  in  the  software. 


The  Universal  Controller  was  built  by  the  Naval  Postgraduate  School  (NPS) 
Power  Research  Group  to  be  used  in  its  research,  specifically  for  the  PEBB  Network 
Simulation  Testbed  [Ref.  4].  The  testbed  is  currently  being  developed  to  help  garner 
understanding  on  how  all  of  the  energy  conversion  devices  within  a  distribution  zone 
interact.  The  Universal  controller  will  enable  the  researchers  to  test  different  control 
algorithms  by  changing  only  the  software  and  not  the  hardware.  In  this  manner,  different 
control  bandwidths  can  be  implemented  so  that  negative-impedance  effects  can  be  readily 
investigated. 

The  Universal  controller  has  no  manual  and  therefore  the  focus  of  this  thesis  is  on 
documenting  how  the  controller  works  and  describing  how  to  implement  desired  control 
algorithms  for  the  SSCM  and  the  SSIM.  In  Chapter  II  the  basic  operation  of  the  SSCM 
and  SSIM  are  presented  and  the  equations  governing  their  circuit  behavior  are  discussed. 
Next,  Chapter  III  deals  with  the  digital  signal  processing  (DSP)  hardware  contained  on 
boards  available  at  NPS  and  then  discusses  the  hardware  associated  with  the  Universal 
Controller.  The  hardware  must  be  controlled  by  a  software  program,  and  in  Chapter  IV 
the  software  provided  by  NSWC  is  investigated.  The  software  provided  by  NSWC  is 
used  to  initialize  the  control  board  and  to  allow  for  a  PC  interface  with  the  board.  This 
allows  data  to  be  downloaded  to  the  controller  via  the  keyboard  on  the  host  PC.  Next  the 
DSP  control  implementation  is  presented  in  Chapter  V.  The  final  chapter  contains  a 
summary  of  the  research  work,  notable  conclusions  and  recommendations  for  future 
work. 


II.         POWER  CONVERTERS 

A.  INTRODUCTION 

The  primary  power  electronic  elements  in  the  DC  zonal  distribution  system  are 
the  Ship  Service  Converter  Modules  (SSCM)  and  the  Ship  Service  Inverter  Modules 
(SSIM).  The  SSCM  processes  the  high-voltage  primary  DC  bus  power  and  produces 
regulated  power  at  a  lower  DC  voltage.  The  SSIM  takes  DC  power  and  converts  it  to 
single-phase  or  three-phase  AC  power.  The  topology  used  for  the  SSCM  is  the  DC-to- 
DC  buck  chopper.  The  topology  for  the  SSIM  is  the  auxiliary  resonant  commutated  pole 
(ARCP)  inverter.     Both  the  buck  chopper  and  the  ARCP  utilize  power  semiconductor 
devices  controlled  by  signal  electronics  to  perform  the  power  conversion.  This  chapter 
contains  a  brief  description  of  the  operation  and  control  of  the  buck  chopper  and  the 
ARCP. 

B.  DC-TO-DC  CONVERTER 

The  buck  chopper,  or  step-down  converter,  is  a  DC-to-DC  converter  in  which  the 
output  voltage  is  always  less  than  the  input  voltage.  The  topology  for  the  buck  chopper  is 
shown  in  Figure  (2-1).  By  controlling  the  amount  of  time  that  the  switch  is  closed  for  a 
given  switching  period,  a  "chopped"  voltage  waveform  between  zero  and  the  DC  input 
voltage  is  realized  across  the  circuit  diode.  The  LC  filter  then  acts  to  filter  out  the  high- 
frequency  harmonics  and  extract  the  average  value.  Closed-loop  control  is  almost  always 
required  to  guarantee  acceptable  transient  and  steady-state  response. 
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Figure  2-1,  Buck  chopper  schematic 


1. 


Basic  Buck  Chopper  Operation 


The  majority  of  the  material  presented  on  the  buck  chopper  is  derived  from 
Mohan  [Ref.  5].  The  voltage  output  of  the  buck  chopper  depends  on  the  duty  cycle, 
which  is  the  ratio  of  the  time  the  switch  is  "on"  to  the  switching  period,  and  the  input 
voltage.  During  continuous  current  operation,  the  following  steady-state  input/output 
relationship  holds. 


D  = 


(2-1) 


Vout  =  DE 


(2-2) 


Assuming  that  C  is  sufficiently  large,  Vout  will  remain  constant.  Figure  (2-2) 
illustrates  typical  relationships  between  the  input  voltage,  duty  cycle  and  output  voltage. 
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Figure  2-2,  Buck  chopper  voltage  waveforms 


There  are  two  modes  of  operation  for  the  buck  chopper,  continuous  and 
discontinuous.  For  the  continuous  case,  the  inductor  current  does  not  go  to  zero  during 
the  switching  period,  whereas  in  the  discontinuous  mode  it  does.  Figure  (2-3)  shows  the 
inductor  current  for  both  cases.  It  is  desirable  to  operate  with  continuous  current  since  in 
this  mode  the  buck  chopper  is  equivalent  to  a  DC  transformer  with  the  turns  ratio 
controlled  electronically  via  the  duty  cycle.  The  energy  storage  capacity  of  the  inductor 
determines  the  mode  of  operation.  The  value  of  the  inductance  at  the  boundary  between 
continuous  and  discontinuous  conduction  modes  is  called  the  critical  inductance  and  is 
given  by  Equation  (2-3). 


T  R 

Lcn,=^rO-D) 


(2-3) 


where  R  is  the  attached  load  resistance. 


H u H*  "...  -*+*- 


(a) 


(b) 


Figure  2-3,  The  inductor  current  for  (a)  continuous  mode;  (b)  discontinuous  mode 


2.  Specifications 

A  medium-power  DC  zonal  electric  distribution  network  simulation  testbed  is 
being  fabricated  at  the  Naval  Postgraduate  School.  The  testbed  is  intended  to  include 
converters  with  device  ratings  and  specifications  that  will  provide  good  representative 
data  sets.  These  data  sets  may  then  be  used  to  assess  stability  boundaries,  transient 
response  and  nonlinear  interaction  between  converters  and  converter  controllers.  The 
buck  chopper  must  meet  the  specifications  shown  in  Table  (2-1).  The  rated  full  load 
resistance  is  10  Q  while  the  minimum  load  before  transitioning  into  discontinuous  current 
operation  is  100  Q.  As  dictated  from  the  specifications,  the  nominal  duty  cycle  is  0.693. 


Rated 
Power 

Switching 
Frequency 

Input 
Voltage 

Output 
Voltage 

Input 
Current 

Output 
Current 

Mode  of 
Operation 

3kW 

20  kHz 

300  V 

208  V 

10A 

14.5  A 

Continuous 

Table  2-1,  Buck  chopper  specifications 


3.  Components 

The  components  shown  in  Figure  (2-1)  make  up  the  basic  buck  chopper  circuit. 
The  switch  is  an  Insulated  Gate  Bipolar  Transistor  (IGBT)  made  by  International 
Rectifier  [Ref.  6].  The  maximum  voltage  VCE  is  600  V  and  the  maximum  current  Ic  is  90 
A.  The  switch  can  be  hard  switched  at  a  frequency  of  25  kHz.  The  IGBT  package 
contains  two  freewheeling  diodes.  Both  diodes  are  used,  one  across  the  IGBT  to  handle 
reverse  currents  through  the  switch,  and  the  other  as  shown  in  Figure  (2-1).  The  values  of 


the  other  components  are  listed  in  Table  (2-2).  The  Lin  and  Cjn  components  form  an  input 
filter  to  the  basic  buck  structure  depicted  in  Figure  (2-1).  If  a  rectifier  is  used  to  supply 
the  input  DC,  this  filter  operates  to  attenuate  the  resultant  harmonics. 


L,„ 

cin 

L 

C 

425  uH 

2000  uF 

HOOuH 

2000  uF 

Table  2-2,  Component  values 


4. 


Interface 


The  IGBT  requires  a  positive  VGE  to  turn  "on"  and  a  negative  VGE  to  turn  "off. 
The  driver  circuit  [Ref.  7]  optically  isolates  the  control  signal  from  the  IGBT  by  use  of  a 
TOSHIBA  TLP  250  gate  drive  photo  IC  coupler.  This  driver  amplifies  the  turn-on  and 
turn-off  voltages  and  protects  the  controller  from  the  large  voltage  swings  occurring 
across  the  IGBT.  Figure  (2-4)  illustrates  a  simplified  gate  driver  for  the  IGBT.  The 
switch  is  on  when  the  control  signal  (light)  is  "on". 
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Figure  2-4,  Simplified  IGBT  driver  circuit. 
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5. 


Control 


The  buck  chopper  must  be  stable,  allow  for  fast  transient  response,  and  allow 
parallel  units  to  share  power  equally.  The  control  algorithm  [Ref.  7]  to  be  implemented 


is: 


d(t)  =  Dss-(hv  +hn  \dtjvQ  -vrej  -iM  -h|(/L  -/0) 


(2-4) 


where, 


d(t)  =  time-varying  duty  cycle 

\  =  voltage  gain 

v0  =  buck  output  voltage 

vref  =  reference  voltage 

iL  =  inductor  current 


Dss  =  steady-state  duty  cycle 
h,,  =  integrator  gain 
h;  =  current  gain 
in  =  load  current 


The  quantity  (v0  -  vref  -  io/10)  represents  the  error  between  the  actual  buck  output  voltage 
and  what  is  desired.  The  io/10  term  represents  a  voltage  droop  which  is  required  for 
paralleling  two  units.  The  control  law  uses  a  current  gain  to  force  the  inductor  current  to 
track  changes  in  the  output  current.  In  addition,  the  proportional  voltage  error  signal  is 
there  for  stability  while  the  integral  term  guarantees  zero  steady-state  error.  The  steady- 
state  duty  cycle  term  represents  feed-forward  action  that  compensates  for  changes  in  the 
input  voltage.  The  controller  must  also  be  able  to  handle  auxiliary  functions  such  as 
limiting  the  current,  temperature  sensing  and  buck  chopper  startup.  Additional  details 
may  be  found  in  reference  [7]. 
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6.  Motivation  for  DSP 

The  control  algorithm  described  above  must  be  implemented  and  tested. 
Designing  the  control  using  software  and  a  universal  DSP  controller  will  significantly 
enhance  the  testing  and  evaluation  of  the  DC-to-DC  converter  by  allowing  flexibility  and 
speed  in  changing  control  algorithms,  adjusting  gains,  and  investigating  different 
switching  frequencies.  Such  modifications  using  the  analog  controller  described  in 
reference  [7]  are  impractical  and  generally  involve  significant  efforts  in  unsoldering 
components  and  inserting  and  tuning  new  ones.  The  PEBB  technology  [Ref  3]  is  based 
on  software  control  capability  and,  in  particular,  configuring  a  single  controller  to  control 
multiple  applications  such  as  both  the  buck  chopper  and  the  ARCP  inverter. 

C.  DC-TO-AC  INVERTER 

The  switch-mode  DC-to-AC  inverter  is  a  power  conversion  device  which  takes 
DC  power  and  produces  an  approximation  to  a  sinusoidal  AC  output  where  both  the 
frequency  and  amplitude  of  the  output  can  be  controlled. 

1.  Basic  Operation 

The  SSIM  is  a  three-phase  inverter.  To  help  explain  the  basic  operation  of  the 
switch-mode  inverter  only  one  phase  of  the  inverter  will  be  discussed.  Switch-mode 
inverters  operate  by  electronically  controlling  the  "on"  times  of  the  switches.  The  switch 
can  be  hard-switched,  which  results  in  high  switching  stresses  and  power  loss,  or  soft- 
switched  (ARCP)  which  reduces  the  switching  stresses  and  power  loss. 
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Figure  2-5,  One  phase  hard-switched  inverter 


a)  Hard-Switched  3-Phase  Inverter 

The  simplified  schematic  of  one  phase  of  a  hard-switched  inverter 
is  shown  in  Figure  (2-5).  For  this  circuit  to  operate,  the  switches  SI  and  S2  open  and 
close  in  a  predetermined  fashion  to  produce  the  AC  output.  In  steady  state  for  any  given 
instant,  only  one  switch  will  be  closed  at  a  time  and  either  the  diode  or  switch  will  be 
carrying  the  current  depending  on  the  direction  of  the  current  flow.  For  example  when  SI 
is  gated  and  S2  is  open,  v^  =  Vd.  If  the  current  flow  is  out,  ia  >  0,  SI  is  conducting.  If  the 
current  flow  is  in,  ia<  0,  Dl  is  conducting.  When  S2  is  gated  and  SI  is  open,  v^  =  0.  If  ia 
>  0,  D2  conducts.  If  ia  <  0,  S2  conducts.  By  connecting  the  return  path  of  the  load  to 
terminal  o,  the  output  vao  alternates  between  ±Vdn-  The  remaining  two  phases  operate  in 
an  analogous  manner  but  have  their  gating  signals  displaced  electrically  by  120°. 
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b)  Auxiliary  Resonant  Commutated  Pole  Inverter 

The  ARCP  inverter  allows  for  zero-switching  voltages  across  the 
IGBTs  which  reduces  the  power  loss  and  switching  stresses  associated  with  the  hard- 
switched  converter.  The  specific  operation  of  an  ARCP  can  be  found  in  [Ref.  8].  Figure 
(2-6)  shows  one  phase  of  the  ARCP.  The  auxiliary  circuit  switches  Al  and  A2  are 
controlled  by  sensing  the  direction  of  the  output  current  and  the  voltages  across  the 
switches  so  that  the  resonant  current,  ir,  will  either  pump  current  to  the  circuit  (ir  >  0) 
when  Dl  or  D2  is  conducting,  or  sink  current  from  the  circuit  (ir  <  0)  when  i0  is  below  a 
certain  threshold  and  conducting  through  SI  or  S2.    In  particular,  these  circuit  switches 
are  only  gated  during  S 1  and  S2  switching  transitions  and  the  high-frequency  resonant 
current  pulse  acts  to  supply  the  needed  energy  to  achieve  zero-voltage  switching. 


Vd/2 


Vd 


+ 
Vd/2 


Cdc/2 


SI     J 


Lr 


Cdc/2 


Al 


A2 


x™ 


Lf 


+      i 


10 


van 


Figure  2-6,  Single  phase  of  the  ARCP 
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2. 


Specifications 


The  ARCP  was  designed  and  assembled  by  the  Applied  Research  Laboratory, 
Perm  State  University  [Ref.  9]  with  the  following  specifications  listed  in  Table  (2-3). 


Operating  Specifications 

PWM  operating  frequency 

0  to  50kHz 

Minimum  dead  time 

1  us 

Nominal  resonant  frequency 

250  kHz 

Maximum  load  rate  (di/dt) 

36  A/us 

Input/Output  Specifications 

Rated  dc  bus  voltage 

400  V 

Maximum  overvoltage 

150  V 

Output  voltage  (3<(i-ac) 

220  V  (rms,line  to  line) 

Output  current  (3<|>-ac) 

17.7  A  (rms) 

Output  voltage  (dc) 

400  V 

Output  current  (dc) 

25  A 

Power  supply  voltage 

24  V  ±  2  V 

Maximum  power  supply  current  @  24  V 

2.2  A 

Drive  signal  inputs 

fiber  optic 

Current  Feedback 

Isolation  from  main  power  bridge 

<  10  Mfi 

Reference 

user  ground 

Bandwidth 

200  kHz 

Scaling  (V/A)  -  This  is  the  scaling  of  the  sensed  current  value 
(1V=10A) 

0.1  V/A 

Limit  -  This  is  the  maximum  voltage  allowed  by  the  current  sensor. 

±  2.75  V 

Table  2-3,  The  ARCP  specifications 
The  units  were  designed  to  contain  three  separate  pole  (phase)  boards  to  facilitate 
operation  as  a  three-phase  unit  or  three  separate  single  phases.  A  control  board  was  also 
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incorporated  to  generate  the  actual  main  and  auxiliary  switch  gating  signals  given  the 
monitored  variables  and  the  commanded  main  switch  signals. 

3.  Components 

Due  to  the  high  resonant  frequency  (250  kHz)  of  the  auxiliary  circuit,  switches  Al 
and  A2  on  Figure  (2-6)  were  chosen  to  be  APT4520  MOSFETs.  These  devices  have  a 
voltage  rating  of  450  V  and  an  on-state  resistance  of  0.20Q.  The  pulse-by-pulse  peak 
current  that  maybe  conducted  through  the  mosFETs  is  92  A  for  a  maximum  period  of  1 0 
fis.  Utilization  of  these  devices  allowed  resonant  cycles  with  a  frequency  as  high  as  325 
kHz. 

The  main  switches  SI  and  S2  were  chosen  to  be  IRGPC50U  IGBTs.  These 
devices  allow  peak  current  carrying  capabilities  of  50  A  at  a  switching  frequency  of  10 
kHz.  Since  the  unit  is  designed  to  accommodate  switching  frequencies  up  to  50  kHz, 
correct  ARCP  operation  (soft  switching)  is  essential  above  1 0kHz. 

The  ARCP  requires  two  sets  of  diodes,  one  set  for  the  main  switches  and  the  other 
set  for  the  auxiliary  circuit.  The  diodes  chosen  for  the  main  switches  are  HEXFRED 
HFA30PA60C  diodes,  which  offered  reasonable  conduction  losses  and  short  recovery 
times.  The  auxiliary  diodes  primary  requirement  is  speed  of  recovery  to  prevent 
circulating  currents  among  the  switches.  The  devices  chosen  were  the  MUR3040,  which 
allow  a  50  ns  reverse  recovery  time. 
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The  passive  component  values  are  as  follows:  Lr «  2.8  uH,  Cdc/2  *  10  u.F,  and 
C/2  »  .05  (J.F.  The  inductance  Lf  listed  in  Figure  (2-6)  is  a  part  of  the  attached  load  and  is 
required  to  satisfy  the  di/dt  specifications  of  the  converter. 


4. 


Interface 


The  ARCP  inverter  requires  the  control  of  four  switches  for  each  phase  of  the 
inverter.  The  auxiliary  switches  are  controlled  internally  by  the  SSIM  unit  while  the 
gating  signals  for  the  main  switches  are  specified  by  an  external  controller.  Figure  (2-7) 
shows  the  circuit  block  diagram  for  a  single  phase  of  the  ARCP.  The  complete  ARCP 
contains  three  separate  phase  boards  each  with  an  identical  block  diagram.  From  this 
diagram,  it  is  clear  that  each  phase  is  composed  of  the  following  sub-circuits:  two  main 
drive  and  voltage  sense  circuits,  two  inner  controller  and  auxiliary  switch  drive  circuits, 
and  an  outer  controller  [Ref.  9]. 
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Figure  2-7,  Circuit  block  diagram  of  the  ARCP  [Ref.  9] 
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The  main  drive  circuitry  takes  the  external  control  signal  (light)  for  the  main 
switches  and  converts  the  signal  into  the  proper  turn-on  or  turn-off  gate  voltages.  This 
circuit  also  detects  the  voltage  across  the  switch  which  then  can  be  monitored  by  the  user. 

The  inner  controller,  labeled  pump  drive  circuit  and  sink  drive  circuit  on  Figure 
(2-7),  controls  the  auxiliary  switches.  The  pump  drive  circuit  turns  "on"  the  bottom 
auxiliary  switch  so  that  current  is  added  to  the  system,  whereas  the  sink  drive  circuit  turns 
"on"  the  top  auxiliary  switch  so  that  it  acts  as  a  current  sink. 

The  outer  controller  block  controls  the  timing  of  the  resonant  switches.  This  is 
accomplished  by  determining  the  direction  and  magnitude  of  the  output  current,  via  the 
current  detection  circuitry,  and  the  voltage  across  the  main  switches.  The  outer  controller 
also  feeds  the  user  control  signals  to  the  main  switch  drivers. 

The  current  detection  circuitry  and  power  supply  block  are  not  physically  located 
on  the  phase  board  but  the  signals  generated  by  these  circuits  and  the  user  control  are 
connected  to  the  outer  controller  via  the  interface  circuitry  block. 

5.  Control 

In  order  to  produce  a  sinusoidal  output  with  the  amplitude  and  frequency 
controllable,  a  more  complex  switching  method  then  the  buck  chopper  is  used.  The 
method  is  called  sine-triangle  pulse  width  modulation  (PWM)  [Ref.  5].  Figure  (2-7) 
shows  a   triangular  waveform  superimposed  on  a  sinusoidal  waveform.  The  triangular 
waveform  is  at  switching  frequency  (fs)  which  establishes  the  frequency  that  the  inverter 
switches  are  gated.  The  sinusoidal  waveform  is  the  control  signal  (vcontro,)  and  is  used  to 
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modulate  the  switch  duty  ratio  and  its  frequency  (/j)  is  the  desired  fundamental  frequency 
of  the  inverter  output.  The  switches  in  the  ARCP  inverter  of  Figure  (2-6)  are  controlled 
based  on  the  comparison  of  vcontrol  and  v^.  When  vcontrol  >  v^  SI  is  "on"  and  vao  =  Vd/2; 
when  vcontro,  <  vtri  S2  is  "on"  and  vao  =-Vd/2.  The  amplitude  is  controlled  by  the  following 
ratio: 

=  Ventral  (2-5) 

V 

¥  tri 

While  in  the  linear  range  of  control,  the  peak  amplitude  of  the  fundamental  frequency 
component  is 


Vfl0I  =  ma  -f  (2-6) 


2 

Closed-loop  control  of  an  inverter  generally  seeks  to  regulate  either  the  three- 
phase  voltages  or  the  three-phase  currents  out  of  the  inverter.  This  is  accomplished  by 
externally  generating  reference  signals  and  comparing  these  with  the  actual  measured 
quantities.  The  resultant  error  signals  are  then  used  to  adjust  the  modulating  waveform 
depicted  in  Figure  (2-8).  Several  closed-loop  inverter  control  schemes  were  investigated 
and  reported  on  in  [Ref.  10]. 

6.  Motivation  for  DSP 

The  ARCP  must  be  tested  with  different  load  configurations  and  control  laws. 
The  use  of  a  DSP  controller  will  allow  flexibility  in  that  the  control  can  be  modified  in 
software  saving  time  and  resources.  The  noise  inherent  in  an  analog  controller  is 
eliminated  and  this  allows  for  a  much  cleaner  output  from  the  ARCP. 
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Figure  2-8,  PWM  (a)  the  sine-triangle  and  (b)  output  waveforms. 
It  is  clear  that  DSP  control  is  a  desired  feature  for  implementing  the  control  of  the  buck 
chopper  and  the  ARCP  inverter.  Personnel  at  the  Naval  Surface  Warfare  Center, 
Annapolis  have  developed  a  control  board  for  the  PEBB  program  called  the  PEBB 
Universal  Controller.  The  Universal  Controller  is  currently  in  the  development  stage. 
This  thesis  will  concentrate  on  using  the  Universal  Controller  hardware  to  implement  the 
control  for  the  buck  choppers  and  the  ARCP  inverters  within  the  NPS  testbed.  The 
Universal  Controller's  hardware  is  examined  in  the  next  chapter. 
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III.       DSP  HARDWARE 

A.  INTRODUCTION 

As  discussed  in  the  last  chapter,  DSP  control  of  the  ship  service  inverter  module 
(SSIM)  and  the  ship  service  converter  module  (SSCM)  offers  flexibility  in  the  design  and 
implementation  of  various  control  algorithms.  Software  control  of  power  electronic 
converters  is  certainly  not  a  novel  idea.  Various  successful  attempts  at  controlling 
devices  have  been  undertaken  at  NPS  [Ref.  10  and  11],  but  identifying  the  most 
appropriate  DSP  hardware  configuration  for  this  type  of  control  has  been  a  problem.  One 
of  the  unique  requirements  for  controlling  either  the  ARCP  inverter  or  the  buck  chopper 
is  that  the  algorithms  for  each  require  many  signals  to  be  monitored  and  processed.  The 
major  limitation  of  the  commercial  boards  that  have  been  used  in  past  efforts  is  the  lack 
of  signal  inputs  available  for  processing.  This  problem  has  motivated  engineers  at  the 
Naval  Surface  Warfare  Center  (NSWC),  Annapolis,  MD,  to  design  a  unique  DSP  product 
called  the  PEBB  Universal  Controller.  The  purpose  of  this  research  is  to  implement  and 
validate  control  algorithms  using  the  NSWC  Universal  Controller.  In  this  chapter,  a 
general  hardware  description  of  this  controller  and  a  brief  overview  of  three  commercial 
DSP  boards  are  presented.  Aspects  of  the  software  control  of  the  Universal  Controller  are 
then  described  in  the  next  chapter. 
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B.  COMMERCIAL  DSP  BOARDS 

The  heart  of  any  DSP  board  is  the  processor.  DSP  processors  can  be  divided  into 
two  broad  categories:  general  purpose  and  special  purpose  [Ref.  12].  Special  purpose 
processors  execute  specific  algorithms  such  as  digital  filters,  FFTs,  and  cosine  transforms 
for  use  in  image  processing.  General  purpose  microprocessors  are  basically  high-speed 
microprocessors  with  hardware  architectures  and  instruction  sets  tailored  for  real-time 
DSP  operations.  DSP  processors  make  use  of  the  Harvard  architecture  which  employs  a 
separate  bus  for  addresses  and  data,  and  different  memory  locations  for  data  and 
instructions.  This  allows  for  full  overlap  of  instruction  fetch  and  execution.  For  example, 
since  the  program  instructions  and  data  lie  in  separate  memory  locations,  the  fetching  of 
the  next  instruction  can  overlap  the  execution  of  the  current  instruction.  Texas 
Instruments  produces  the  TMS320  family  of  general  purpose  DSP  chips.  The  TMS320 
processors  use  a  modified  Harvard  architecture.  In  the  modified  architecture,  separate 
program  and  data  memory  spaces  are  still  maintained,  but  communication  between  the 
two  memory  spaces  is  permissible.  All  of  the  DSP  boards  that  have  been  encountered  in 
this  research  effort  and  are  available  at  NPS  contain  the  TMS320C30/31  DSP  processor. 
These  include: 

•  C30  system  board  by  LSI  (SPECTRUM  Signal  Processing  Inc.) 

•  SBC3 1  system  board  by  Innovative  Integrations  Digital  Signal  Processor 

•  LD3 1  system  board  by  dSPACE  (digital  signal  processing  and  control 
engineering). 
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The  C30  board  features  the  Texas  Instruments  TM320C30  general  purpose  DSP 
processor.  This  board  contains  two  banks  of  off  chip  memory  for  a  total  of  128K  words. 
The  on  board  memory  allows  for  quick  access  to  data.  Dual  channel  1 6  bit  A/D  and  D/A 
converters  are  included  on  the  board  with  sampling  rates  of  up  to  200  kHz.  The  board  is 
suitable  only  for  PC/AT  and  compatibles,  since  it  uses  the  full  1 6-bit  interface.  All 
communication  with  the  board  is  via  the  I/O  space  of  the  PC.  Access  to  memory  passes 
are  through  the  dual  porting  hardware  on  the  board.  Reference  [13]  has  the  complete 
details  for  this  board. 

The  SBC3 1  board  is  based  on  the  Texas  Instruments  TM320C3 1 .  The  SBC3 1  is  a 
stand  alone  card  with  128K  of  on-board  Programmable  Read  Only  Memory  (PROM)  and 
32K  of  Static  Random  Access  Memory  (SRAM)  for  user  programs.  The  PROM  contains 
the  program  instructions  and  the  SRAM  is  for  data  storage  and  retrieval.  The  board 
includes  one  dual  channel  1 6-bit,  200  kHz  A/D  converter  and  2  dual  channel  D/A 
converters.  The  board  contains  two  serial  ports.  A  remote  PC  can  be  connected  via  the 
RS232  connector  to  communicate  with  the  board.  This  board  was  used  for  implementing 
a  digital  control  algorithm  for  a  DC-to-DC  buck  chopper  previously,  but  had  some 
serious  limitations  [Ref.  11].  The  most  significant  limitation  was  the  delay  times 
associated  with  the  A/D  converters.  The  large  delay  time  occurred  because  of  two 


reasons: 


1 .  One  A/D  converter  was  used  to  sample  4  signals  . 

2.  The  A/D  converter  is  double  buffered;  therefore,  two  conversion  cycles  are 
required  before  the  sampled  data  is  available  for  computations. 
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The  third  DSP  board  available  at  NPS  is  the  digital  Signal  Processing  And  Control 
Engineering  (dSPACE)  DS1 102  controller  board.  This  board  can  be  inserted  into  any  16- 
bit  slot  on  a  PC/AT  computer.  The  DS1 102  is  based  on  the  Texas  Instrument 
TMS320C31.  This  board  contains  two  16-bit  A/D  converters  and  two  12-bit  A/D 
converters  [Ref.  14].  One  of  the  benefits  of  the  DS1 102  is  that  it  comes  with  software 
that  allows  the  user  to  interface  with  the  Math  Works  development  software  MATLAB 
and  SIMULINK.  This  facilitates  the  design  and  implementation  of  a  controller  using  the 
graphical  modeling  capabilities  of  SIMULINK.  C  code  can  then  be  generated  from  the 
SIMULINK  design  and  compiled  by  the  TMS  C  compiler.  This  makes  the  dSPACE 
board  very  easy  to  work  with.  The  board  does  have  significant  limitations.    As 
documented  in  Reference  [10],  the  DS1 102  was  limited  to  single-phase  operation  of  the 
ARCP  inverter  because  of  the  limited  number  of  I/O  ports.  In  addition,  there  are 
conservative  bounds  on  the  complexity  of  the  algorithm  that  maybe  loaded  form 
SIMULINK  into  the  board. 

As  mentioned  at  the  beginning  of  the  chapter  NSWC,  in  conjunction  with  the  PEBB 
program,  developed  their  own  DSP  controller.  This  controller  was  designed  primarily  for 
power  electronic  circuits,  and,  specifically,  for  the  intensive  input/output  requirements  of 
the  ARCP. 

C.  NSWC  PEBB  UNIVERSAL  CONTROLLER 

The  PEBB  Universal  Controller  was  designed  to  control  various  applications  as 
shown  in  Figure  (3-1).  Presently  the  application  which  requires  the  most  I/O  support  is 
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the  ARCP,  which  requires  as  many  as  12  gate  signals  and  the  ability  to  convert  10  analog 
signals  to  digital  signals.  Each  phase  of  the  ARCP  inverter  has  4  gates  to  be  controlled: 
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Figure  3-1,  PEBB  package  diagram  [Ref.  4] 
two  main  switches  and  two  auxiliary  switches  (see  Chapter  II).  The  units  delivered  to 
NPS  have  a  provision  wherein  the  auxiliary  switches  may  be  controlled  by  the  unit  itself. 
In  general,  however,  control  of  all  12  switches  requires  sampling  the  output  voltage  and 
current  of  each  phase  and  the  input  voltage  and  current.  By  designing  the  DSP  board  to 
handle  the  most  I/O  intensive  application,  switching  to  other  applications  only  involves 
changing  the  software  and  not  the  hardware. 
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1. 


General  Description 


The  Universal  Controller  is  built  around  the  TMS320C30  DSP  chip  and  is 
contained  on  two  boards,  the  mother  board  (CPU  board)  and  the  daughter  board  (I/O 
board).  Figure  (3-2)  shows  the  CPU  board  and  I/O  board  external  connections. 
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Figure  3-2,  Universal  controller  CPU  and  1/0  boards  [Ref.  15] 
Communication  with  the  CPU  board  is  accomplished  via  the  RS232  serial  port  on  a  host 
PC.  The  signal  from  the  host  PC  is  converted  to  an  optical  signal  and  read  by  the  CPU 
board.  The  board  also  can  send  information  to  the  PC  such  as  voltage  and  current  values 
for  display  on  the  screen.  The  1/0  board  contains  all  the  voltage  and  current  sensor  inputs 
and  also  sends  the  gate  signals  to  the  switches.  In  Figure  (3-2),  XD  and  XA  correspond  to 
the  32-bit  TMS320  expansion  data  bus  and  the  expansion  address  bus  respectively.  The 
LDB  is  a  16-bit  data  bus  from  the  mirocontroller  contained  on  the  CPU  board.  The  L 
signifies  that  the  microcontroller  is  connected  to  the  left  side  of  the  dual  port  memory 
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which  is  discussed  below.  The  I/O  board  shows  the  10  current/voltage  sensors  (on  the 
left  of  the  diagram)  which  are  connected  to  the  A/D  converters  and  1 2  gate  connections 
(on  the  right  of  the  diagram)  which  are  the  optical  transmitters  used  to  drive  the  switching 
circuits.  The  LED  connection  is  used  to  display  the  current  mode  of  operation  (e.g. 
ARCP  control  or  buck  control).  The  inputs  [0..7]  (on  the  left  of  the  diagram)  can  be  used 
to  start  and  stop  the  controller  locally.  The  input  and  LED  connections  are  not  used  in 
this  research  effort. 

2.  Primary  Components 

The  primary  components  of  the  Universal  Controller  can  be  divided  up  into  the 
following  five  categories:  processor,  memory,  PC  interface,  analog  interface,  and 
timer/counters.    A  brief  description  of  each  of  these  components  follows.  A  complete 
listing  of  all  the  parts  contained  in  the  Universal  Controller  is  given  in  Appendix  A. 

a)  Processor 

The  processor  is  the  181-pin  grid  array  TMS320C30  from  Texas 
Instruments  [Ref.  16].  The  C30  is  operating  from  a  40  MHz  clock  which  results  in  a  50 
ns  instruction  cycle  time  and  the  performance  of  20  million  instructions  per  second.  The 
peak  arithmetic  performance  is  40  million  floating-point  computations  per  second  when 
the  floating-point  multiplier  and  adder  are  used  in  parallel.  The  C30  contains  one  4K  x 
32-bit,  single-cycle,  dual-access,  on-chip  ROM  block  and  two  IK  x  32-bit  RAM  blocks. 
The  C30  can  be  set  up  in  two  different  modes,  microprocessor  mode  or  microcomputer 
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mode.  The  memory  map  (see  Figure  3-3)  depends  on  which  mode  the  processor  is 
running  in.  The  default  mode  for  the  Universal  Controller  is  the  microprocessor  mode. 
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Figure  3-3,  Memory  map  for  microprocessor  mode. 
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The  details  of  the  memory  map  will  be  discussed  in  Chapter  IV.  Other  key  features  of  the 
microprocessor  are: 

•  64  x  32  instruction  cache 

•  32-bit  instruction  and  data  words 

•  24-bit  addresses 

•  40-/32-bit  floating-point/integer  multiplier  and  ALU 

•  Eight  extended-precision  registers  (accumulators) 

•  Two  address  generators  with  eight  auxiliary  registers  and  two  auxiliary 
register  arithmetic  units 

•  On-chip  DMA  controller  for  concurrent  I/O  and  CPU  operation 

•  Parallel  ALU  and  multiplier  instructions  in  a  single  cycle 

•  Two  32-bit  data  buses  (24-  and  1 3 -bit  address) 

•  Two  3  2 -bit  timers 

•  Two  general-purpose  external  flags;  four  external  interrupts. 

Figure  (3-4)  shows  a  functional  block  diagram  to  illustrate  the  interrelationships  between 
the  various  C30  key  components.  Figure  (3-4)  does  not  show  the  port  control  registers. 
The  port  control  registers  consist  of  two  32-bit  registers,  one  for  the  primary-bus  control 
and  the  other  for  the  expansion-bus  control.  The  primary  bus  control  is  set  up  to  allow 
for  1  wait  state  and  1 M  bank  compare  to  allow  for  reading  from  the  PROM  and  static 
random  access  memory  (SRAM).  The  expansion  bus  is  set  up  to  allow  for  2  wait  states 
which  are  required  for  reading  the  values  from  the  slower  A/D  converters  and  writing 
control  words  and  count  values  to  the  counter/timers. 
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Figure  3-4,  The  TMS320C3x  block  diagram  [Ref.  16]. 

b)  Memory 

The  external  memory  is  divided  into  three  memory  areas.  Figure 
(3-4)  shows  the  block  diagram  of  the  CPU  board  and  the  locations  for  the  three  memory 
areas.  The  first  area  is  the  programmable  read  only  memory  (PROM).  This  is  where  the 
program  code,  which  is  discussed  in  the  next  chapter,  is  located.  Four  WSI  WS57C256F- 
35  32K  x  8  power  switched  and  reprogrammable  PROM  chips  were  selected.  The 
TMS320C30's  32-bit  primary  bus  is  divided  up  between  the  four  PROMs,  which  have  8- 
bit  word  memory.  An  address  decoder  is  used  so  that  a  memory  read  will  read  the  same 
memory  location  on  all  four  PROMs  simultaneously  to  generate  the  32-bit  word  for  the 
microprocessor.  The  CPU  board  has  28-pin  sockets  to  allow  the  PROM  to  be  removed 
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for  programming.  The  PROM  is  memory  mapped  to  40h.  This  means  that  the  address  for 
the  top  memory  location  of  the  PROM  is  located  at  40  hex. 

The  next  memory  area  is  the  static  RAM.  The  static  RAM  is  made  up  of  four 
IDT71256SA  fast  32K  x  8  CMOS  chips.  A  memory  read  or  write  works  just  like  a 
memory  read  for  the  PROM.  The  static  RAM  is  memory  mapped  to  80000h.  Figure  (3- 
5)  shows  the  location  of  the  static  RAM  on  the  CPU  board. 
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dual  port  memory 

PROM 

PROM 

PROM 

PROM 

TMS320C30 

SRAM 

SRAM 

SRAM 

SRAM 

Figure  3-5,  The  Universal  Controller  CPU  board  showing  key  components 
The  last  memory  area  is  the  dual-port  memory.  The  IDT7130SA  high-speed  IK  x 
8  dual-port  static  RAM  from  Integrated  Device  Technology  was  selected  for  use  on  the 
Universal  Controller.  The  dual-port  memory  allows  the  DSP  chip  to  access  data  that  may 
be  downloaded  to  the  dual-port  memory  from  the  host  PC.  The  dual-port  memory  is 
memory  mapped  to  lOOOOOh.  Figure  (3-5)  shows  the  location  of  the  dual-port  memory 
on  the  CPU  board. 
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c)  PC  Interface 

The  PC  communicates  with  the  universal  controller  board  by  a 
windows  C++  program  that  sends  data  and  commands  through  one  of  the  communication 
ports  to  the  Universal  Controller.  The  Universal  Controller  contains  two  optical 
receivers.  One  to  receive  data  from  the  host  PC,  and  the  other  to  receive  data  from 
another  Universal  Controller.  Since  the  Universal  controller  must  receive  an  optical 
signal,  the  signal  from  the  PC  must  be  converted  to  an  optical  signal  as  shown  in  Figure 
(3-6).  The  RS-232  port  from  the  host  computer  is  connected  to  a  optical 
transmitter/receiver  box.  Pins  2,  3,  4,  and  7  of  the  RS-232  are  used  and  correspond  to: 
transmitting  data,  receiving  data,  requesting  to  send  data,  and  signal  ground  respectively. 


Fiberoptic  cabling 


optical 
transmitter 


universal 
controller 


Figure  3-6,  PC  interface. 
The  optical  transmitter/receiver  box  uses  a  MAX232CPE  +5V  RS-232  transceiver  to 
drive  the  optical  transmitter  and  receiver  ports.  The  data  is  sent  to  the  microcontroller  on 
the  CPU  board,  Figure  (3-5).  The  microcontroller  is  Intel's  87C51FA.  The 
microcontroller  can  write  to  the  dual-port  memory,  interrupt  the  DSP  processor,  and  send 
commands  to  the  DSP  processor.  It  is  operating  from  a  16  MHz  clock.  The  8751  must 
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be  programmed  in  conjunction  with  the  C++  windows  program  for  the  interface  to  work. 
An  engineer  at  NSWC,  Annapolis  has  written  both  the  C++  PC  code  and  the  875 1 
assembly  code  to  allow  for  limited  interaction  with  the  Universal  Controller.  Currently 
the  PC  can  download  20  parameters  to  the  dual  port  memory  and  send  commands  to  start 
and  stop  the  controller. 

d)  Analog  Interface 

The  input/output  board  contains  1 1  Maxim  500ksps  12-bit  A/D 
converters.  The  sensed  voltages  and  currents  are  connected  to  the  I/O  board  via  twisted 
pair.  The  input  range  is  ±  5  volts  and  the  conversion  time  is  2.6  us.  The  I/O  board  has 
one  20  MHz  clock  and  a  Motorola  SN74LS93  4-bit  binary  counter  that  is  used  to  convert 
the  20  MHz  clock  into  a  5  MHz  clock  for  the  A/D  converters.  The  conversion  takes  13 
clock  cycles  and  one  clock  cycle  takes  l/5MHz  =  0.2  (is;  therefore,  total  conversion  time 
is  13(0.2  (is)  =  2.6  (is.  The  A/D  converters  are  set  up  in  the  ROM  mode.  This  means  that 
the  converter  acts  like  a  fast-access  memory  location.  There  are  1 0  input  connections  and 
1 1  A/D  converters.  The  1 1th  A/D  converter  is  used  to  convert  a  selected  analog  input 
signal  to  a  digital  signal  for  purposes  of  displaying  on  an  LCD  screen.  There  are  5 
memory  locations  for  the  1 0  A/D  converters.  A  read  to  one  memory  location  will  initiate 
a  conversion  on  two  A/D  converters  and  will  also  read  the  data  from  the  previous 
conversion.    The  time  between  successive  read  operations  must  be  greater  than  the  sum 
of  the  conversion  time  (2.6  (is)  and  the  track/hold  acquisition  time  (.35  (is)  [Ref.17]. 
Figure  (3-7)  shows  the  I/O  board  and  the  1 1  A/D  converters. 
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Figure  3-7,  The  Universal  Controller  I/O  board  showing  key  components 
e)  Timer/Counters 

There  are  four  Harris  82C54  counter  timers  on  the  I/O  board  as 
shown  in  Figure  (3-6).  The  20  MHz  clock  mentioned  above  is  converted  to  a  10  MHz 
master  clock  signal  via  the  SN74LS93  4-bit  binary  counter.  This  master  clock  signal  is 
used  by  all  4  counter  timers  and  the  3  programmable  logic  devices  (PLD).  As  mentioned 
earlier,  the  Universal  Controller  was  designed  for  operating  the  ARCP  inverter  which 
requires  12  gate  signals  (when  controlling  both  the  main  and  auxiliary  switches).  Figure 
(3-7)  illustrates  that  there  are  3  sets  of  4  optical  transmitters  (phase  a,  phase  b,  and  phase 
c)  and  that  each  set  is  controlled  by  1  PLD  and  each  PLD  has  a  separate  counter/timer  and 
a  common  counter/timer  connected  to  it.  The  PLD  is  programmed  to  operate  the  2  main 
switches  and  the  2  auxiliary  switches  on  a  single  phase  of  the  ARCP  inverter.  The 
counter  timers  can  be  controlled  by  software  and  will  be  discussed  in  the  next  chapter. 


34 


Each  counter  timer  has  3  counters,  a  control  word  register,  and  a  data  input 
register.  For  the  ARCP  inverter,  C/T  1  is  set  up  in  rate  generator  mode.  This  mode 
establishes  the  switching  frequency.  The  master  clock  is  a  10  MHz  clock  which 
corresponds  to  Tpulse  =  100  ns.  For  a  10  kHz  switching  frequency,  the  switching  period  is 
Tsw  =  l/fsw  =  100  (is.  The  100  us  is  timed  by  counting  1000  counts  (1000  x  100  ns  =  100 
(j.s)  on  one  of  the  counters  in  C/T  1 .  The  other  2  counters  in  C/T  1  are  set  up  to  count  to 
1000  also,  but  they  are  delayed  so  that  each  counter  in  C/T  1  generates  a  pulse  every  100 
fis  and  each  pulse  is  separated  by  1/3  of  the  switching  period,  or  120°.  C/T  1  is 
designated  the  switching  frequency  counter  and  each  counter  output  is  used  by  a  PLD, 
one  for  each  phase,  separated  by  120°.  The  PLDs  will  generate  an  external  interrupt  on 
the  C30  DSP  processor  by  each  pulse  generated  by  C/T  1,  allowing  data  reads  from  the 
A/D  converters  and  control  calculations  to  be  performed  by  the  processor.  The  other  3 
counter  timers  are  set  up  to  operate  in  hardware  retriggerable  one-shot  mode.  In  this 
mode  the  PLD  will  trigger  a  counter  and  the  output  of  the  counter  will  go  low  for  a 
predetermined  count  (whatever  count  is  written  to  the  counter)  and  then  go  high  until 
triggered  again.  Each  PLD  and  C/T  combination  along  with  the  counts  associated  in  each 
counter  will  drive  the  optical  transmitters  and  control  up  to  12  gates.  The  detailed 
schematic  of  the  PLD  is  contained  in  Appendix  B. 

3.  Architecture  Overview 

As  stated  earlier,  the  Universal  Controller  is  contained  on  two  boards,  a  CPU 
board  and  an  I/O  board.  The  boards  are  connected  by  a  96-pin  snap-on  connector.  Figure 
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(3-8)  shows  the  block  diagram  and  how  the  two  boards  are  connected.  The  Universal 
Controller  is  powered  by  a  Condor  DC  power  supply  model  HDCC-150W-A+.  The 
power  supply  is  rated  at  5V,  12A  and  ±12V,  3.4A.  The  5V  is  connected  to  the  CPU 
board  and  powers  all  the  digital  electronics  on  both  boards.  The  ±12V  is  connected  to  the 
I/O  board  and  powers  the  input  signal  buffers  and  A/D  converters.  A  complete  set  of 
schematics  is  located  in  Appendix  B. 
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Figure  3-8,  Block  diagram  of  the  Universal  Controller  [Ref.  15]. 
The  hardware  elements  in  Figure  (3-8)  work  together  to  provide  the  control  of  the 
SSIM  and  the  SSCM.  For  example,  to  control  the  SSCM,  the  first  requirement  is  to  burn 
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the  control  code  into  the  EPROM.  The  code  will  need  parameters  such  as  switching 
frequency,  reference  voltage,  and  gain  constants.  These  parameters  are  downloaded  to 
the  dual  port  memory  from  the  host  PC  via  the  8751  microcontroller.  The  8751 
controller  will  start  and  stop  the  controller  by  commands  issued  from  the  host  PC.  Once 
the  host  PC  starts  the  controller,  the  DSP  processor  will  initialize  the  board  to  run  the 
SSCM  program.  Initialization  consists  of  loading  the  control  parameters  from  the  slower 
dual  port  memory  to  the  faster  on-chip  RAM  and  initializing  the  counter/timers  according 
to  the  control  parameters.  Only  one  gate  driver,  one  duty  cycle  C/T,  four  A/D  converters 
and  the  switching  frequency  C/T  are  needed  to  control  the  SSCM;  therefore,  one 
Universal  Controller  can  control  two  SSCMs.  The  input  voltage,  inductor  current,  output 
current  and  output  voltage  are  sampled  and  converted  to  digital  signals.  The  signals  are 
used  to  calculate  the  proper  duty  cycle  which  in  turn  corresponds  to  an  integer  count 
value  that  must  be  written  to  the  duty  cycle  C/T.  This  will  produce  the  gate  driver  signal 
to  be  optically  transmitted  to  the  SSCM.  The  SRAM  is  not  needed  for  the  SSCM  code 
but  is  required  for  sine  triangle  pulse-width  modulation  control  for  the  SSIM  A  large 
lookup  table  is  generated  and  stored  in  this  memory  location. 

The  TMS320C30  must  be  programmed  to  implement  the  specific  control 
algorithms.  The  software  implementation  is  discussed  in  the  next  chapter. 
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IV.       DSP  SOFTWARE  AND  FIRMWARE 

A.  INTRODUCTION 

As  discussed  in  Chapter  III,  the  Universal  Controller  consists  of  many  hardware 
components  that  must  be  programmed  in  order  to  operate.  The  host  PC  must  contain 
software  that  allows  it  to  communicate  with  the  DSP  processor,  and  the  DSP  processor 
must  be  able  to  communicate  with  all  of  the  input/output  components  as  well  as  the 
counter/timers.  In  this  chapter  the  software  and  firmware  requirements  of  the  Universal 
Controller  are  introduced  and  discussed.  The  term  software  is  defined  within  this 
document  as  being  computer  program  instructions,  and  the  term  firmware  is  defined  as 
the  combination  of  a  hardware  device,  such  as  the  87C51,  and  the  computer  instructions 
or  computer  data  that  reside  as  read-only  software  on  the  hardware  device.  The  software 
and  firmware  that  is  required  to  operate  the  Universal  Controller  can  be  broken  up  into 
two  categories:  interface  software  and  firmware  and  TMS320C30  firmware. 

The  interface  programming  consists  of  firmware  and  software  that  allow 
components  to  communicate  with  each  other.  For  example,  the  87C51  microcontroller 
must  be  programmed  to  accept  parameter  data  from  the  host  PC  and  store  this  data  in  an 
exact  memory  location  within  the  dual  port  memory.  This  interface  software  and 
firmware  is  provided  by  NSWC. 

The  TMS320C30  must  be  programmed  to  do  the  mathematical  computations 
required  by  the  control  algorithm.  This  code  is  assembled  and  is  loaded  into  the  EPROM. 
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It  is  the  TMS320C30  code  that  contains  the  control  algorithms  developed  here  at  NPS  for 
controlling  the  SSIM  and  the  SSCM. 

B.  NSWC  PROVIDED  SOFTWARE  AND  FIRMWARE 

The  interface  hardware  that  is  programmed  by  NSWC  includes  the  87C51 
microcontroller,  the  programmable  logic  devices  (PLDs),  and  one  address  decoder.  The 
host  PC  must  also  be  programmed  to  communicate  with  the  Universal  Controller.  Since 
the  user  enters  parameters  and  starts  and  stops  the  controller  with  the  host  PC,  the 
primary  emphasis  of  this  section  will  be  on  the  host  PC  software.  A  brief  overview  will 
then  follow  covering  the  remaining  firmware. 

1.  Host  PC  Software 

The  host  PC  software  is  a  visual  C++  program  written  in  Microsoft  Windows 
Visual  C++  version  1.5  for  Windows  3.1.  The  program  was  written  specifically  to 
demonstrate  the  capability  of  the  Universal  Controller  by  controlling  a  specific  NSWC 
power  electronic  device  depending  on  the  mode  selected  by  the  software.  Since  the  main 
function  of  the  host  PC  is  to  pass  parameters  to  the  dual  port  memory  and  start  and  stop 
the  controller,  the  software  did  not  need  modification  here  at  NPS.  The  software,  as 
written,  will  suffice  to  pass  the  parameters  needed  for  both  ARCP  inverter  operation  and 
buck  chopper  operation.  Also  depending  on  the  mode  you  select,  the  host  PC  will  signal 
the  controller  to  initiate  or  stop  the  desired  control  algorithm.  This  software  is  installed 
on  the  research  computer  in  the  power  lab.  Installation  instructions  are  included  in 
Appendix  C. 
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To  operate  the  software  you  must  open  the  main  window.  The  main  window  will 
be  displayed  by  double  clicking  the  left  button  on  the  PEBB  icon  located  in  the  PEBB 
working  group  window.  The  program  itself  is  Pebb.exe  and  is  located  in  the 
C:\Pebb\win31new  directory.  As  illustrated  in  Figure  (4-1),  the  PC  can  control  two 
Universal  Controllers,  unit  1  and  unit  2.  Each  unit  has  its  own  "ON"  and  "OFF"  buttons 
and  an  "ON/OFF"  display  indicating  the  current  status  of  the  unit.  Before  either  unit  can 
be  activated,  a  data  link  must  be  established.  The  data  transfer  between  the  PC  and  the 
controller  is  done  through  one  of  the  PC's  communication  ports. 


PEBB  -  DEMO 

File 

Com  Port    Mode    Settings 

NSWC/CD  -  PEBB  1  DEMO 

UNIT1 

DC  to  DC  Buck  Mode 

UNIT  2 

Test  Mode 

OFF 

OFF 

ON 

OFF 

ON 

OFF 

RS232  Communications  Status 
COM2  Port  Enabled 

Figure  4-1,  The  main  window  for  the  host  PC  software 
The  Universal  Controller  is  connected  to  the  research  computer  via  COM2.  To 
tell  the  host  PC  which  COM  port  each  unit  is  connected  to,  the  Com  Port  menu  item  must 
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be  selected  as  shown  in  Figure  (4-2).  The  demo  software  allows  two  units  to  be 
connected  to  one  COM  Port  at  one  time.  One  PC  can  operate  more  than  two  controllers  if 
additional  COM  Ports  are  available.  Each  Universal  Controller  has  a  5-pin  dip  switch  on 
the  CPU  board.  Setting  the  first  switch  to  "on"  and  the  other  four  switches  to  "off 
corresponds  to  unit  1 .  Setting  up  unit  1  to  run  the  DC-to-DC  buck  (SSCM)  is  illustrated 
in  Figure  (4-2).  The  COM  port  must  be  selected  first  followed  by  the  mode  selection. 
The  last  menu  selection  is  the  Settings  menu.  By  clicking  on  the  UNIT  1  selection  under 
Settings,  a  separate  window  is  opened.  This  window  is  shown  in  Figure  (4-3).  From  here 
the  user  can  enter  up  to  20  parameters.  It  should  be  noted  that  the  names  associated  with 
the  parameters  in  the  settings  window  are  fixed  and  are  associated  with  the  parameters 
needed  for  the  operation  of  the  NSWC  ARCP.  As  a  consequence,  in  order  to  use  the 
same  interface  software  while  controlling  the  NPS  SSCMs,  the  variable  names  listed  in 


COM  PORT 

MODE 

Settings 

Port 

COM1 
COM2 

COM3 
COM4 

UNIT1 

Test  Mode 
DC  to  AC 
Motor  Control 
Actuator  Control 
Linear  Actuator  Control 
DC  to  DC  Boost 
DC  to  DC  Buck 

UNIT1 

UNIT  2 

UNIT  2 

Figure  4-2,  Host  PC  software  menu  settings  for  SSCM  operation. 
Figure  (4-3)  will  necessarily  need  to  be  used  to  represent  SSCM  parameters.  Therefore, 
this  window  is  merely  a  channel  to  pass  parameters  to  the  Universal  Controller  that  need 
to  be  changed  on  the  fly.  For  example,  to  test  the  response  to  of  the  SSCM  for  different 
control  gains,  KC,  KCB,  and  BT  are  used  to  pass  these  parameters  to  the  CPU  board 
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instead  of  reprogramming  the  PROMs.  More  details  on  the  parameters  entered  for  the 
SSCM  will  be  given  in  Chapter  V. 

The  parameters  are  passed  to  the  dual  port  memory  by  clicking  on  the  "OK" 
button  in  the  settings  window.  Only  after  the  parameters  have  been  passed  to  the  CPU 
may  the  controller  be  turned  on.  The  red  LED  light  on  the  CPU  board  will  illuminate  to 
indicate  that  the  CPU  received  the  "turn  on"  command  by  the  host  PC. 


UNIT1 

AC  RMS  VOLTAGE 

120 

AC  TRIP  CURRENT 

300 

AC  RMS  CURRENT 

10 

DC  TRIP  CURRENT 

200 

DC  VOLTAGE 

300 

BOOST  TIME 

20 

DC  CURRENT 

10 

BOOST  DELAY  TIME 

80 

OUTPUT  FREQUENCY 

60 

DEAD  TIME 

160 

SWITCHING  FREQUENCY 

10000 

BLOCK  SIZE 

2000 

AC  SENSOR 

500 

DC  SENSOR 

500 

STEP 

10 

DELAY 

50 

KC 

10 

BT 

2000 

KCB 

10 

Bl 

2000 

OK 

CANCEL 

Figure  4-3,  Unit  1  settings  window. 
Other  modes  listed  in  Figure  (4-2)  are  modes  that  correspond  to  the  NSWC 
TMS320C30  firmware.  With  the  NSWC  PROMs  installed,  selecting  the  test  mode  will 
operate  the  ARCP  inverter  open  loop.  The  DC  to  AC  mode  is  specifically  designed  to 
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operate  the  NSWC  ARCP  inverter  closed  loop.  The  motor  control,  actuator  control, 
linear  actuator  control,  and  DC  to  DC  boost  modes  are  modes  to  operate  specific  NSWC 
devices  for  PEBB  demonstrations. 

2.  Microcontroller  Firmware 

The  microcontroller  must  be  programmed  in  order  to  operate  the  Universal 
Controller.  The  87C51  has  4K  bytes  of  on-chip  PROM  to  store  the  program.  This  means 
that  rather  than  using  an  external  PROM  chip,  the  program  can  be  burned  directly  into  the 
87C51.  The  instruction  set,  assembly  language  and  the  use  of  the  8051  assembler 
(ASM51)  are  described  in  reference  [18]. 

The  purpose  of  the  microcontroller  is  to  interface  between  the  host  PC  and  the 
TMS320C30  DSP  microprocessor  as  described  in  Chapter  III.  This  is  accomplished  in 
the  following  way.  First  the  87C51  checks  to  see  what  address  is  selected  on  the  5-pin 
dip  switch.  For  example,  if  the  switch  was  configured  to  correspond  to  unit  1  (as 
explained  above),  data  sent  to  the  controller  from  the  host  PC  for  unit  2  would  be  ignored 
by  the  CPU  board  with  a  unit  1  address.  If  data  being  sent  from  the  host  PC  is  for  unit  1, 
the  microcontroller  will  accept  the  data  and  process  it.  The  microcontroller  will  store  the 
parameters  from  the  unit  settings  window  in  the  dual  port  memory  to  be  read  by  the  DSP 
microprocessor  later.  The  87C5 1  will  also  interrupt  the  DSP  processor.  The  interrupts 
pass  commands  to  the  DSP  microprocessor  to  either  start  or  stop  the  execution  of  the 
desired  control  algorithm. 
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3.  Programmable  Logic  Device 

There  are  three  PLDs  on  the  I/O  board.  These  devices  contain  the  logic  to  operate 
the  gate  drivers  connected  to  the  optical  transmitters.  Each  PLD  controls  four  optical 
transmitters,  one  for  each  gate  on  a  single  phase  of  the  ARCP.  The  NPS  ARCP  does  not 
require  all  four  optical  transmitters  since  it  has  its  own  auxiliary  circuit  controller; 
therefore,  only  two  of  the  four  optical  transmitters  per  phase  are  used  to  control  the  main 
switches.  The  PLD  logic  produces  gate  signals  as  illustrated  in  Figure  (4-4)  with  a  1 .2  us 
delay  time  between  them.  This  delay  time  is  referred  to  as  "dead  time"  and  is  required  by 
the  outer  controller  block  of  the  ARCP  as  discussed  in  Chapter  II.  This  dead  time 
prevents  both  upper  and  lower  switches  from  being  "on"  at  the  same  time. 


upper  switch 


lower 
switch 


switching  period 


-►    <- 


dead  time 


Figure  4-4,  The  signal  produced  by  the  PLD  logic. 
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All  three  PLDs  have  the  same  logic  burned  in  them.  As  shown  in  Figure  (3-7),  each  PLD 
has  its  own  counter/timer  connected  to  it  and  one  shared  counter/timer  connected  to  it. 
The  shared  counter  timer  is  called  the  switching  frequency  timer  (this  will  be  explained 
later).  Each  PLD  generates  a  switching  period  using  the  shared  counter/timer  and  a  duty 
cycle  using  the  dedicated  counter/timer.  For  example,  if  the  desired  switching  frequency 
is  20  kHz  the  switching  frequency  timer  must  have  an  integer  value  of  500  in  its  counter 
register.  This  is  because  each  count  takes  100  ns  and  500  x  100  ns  =  50  \±s  which  is  the 
desired  switching  period  for  20  kHz.  The  duty  cycle  is  determined  by  the  count  that  is 
stored  in  the  second  counter  register  (each  counter/timer  has  3  counters)  on  the  dedicated 
counter/timer.  If  this  count  is  250,  a  50%  duty  cycle  will  be  produced.  More  details  will 
be  documented  in  Chapter  V. 

4.  Address  Decoders 

In  addition  to  the  PLDs  required  for  controlling  the  optical  transmitters,  a  fourth 
PLD  is  needed  for  address  decoding.  The  EPM5016  is  used  for  reading  memory  from  the 
four  EPROM  chips  and  four  SRAM  chips.  The  TMS320C30  has  a  32-bit  data  bus  and 
the  EPROM  and  SRAM  contain  8-bit  memory  locations.  The  EPM5016  is  programmed 
so  that  one  read  by  the  microprocessor  will  produce  a  32-bit  word  from  either  the  four 
SRAMs  or  the  four  PROMs. 

C.  TMS320C30  FIRMWARE 

The  TMS320  family  of  DSPs  are  supported  by  a  complete  set  of  software 
development  tools,  including  an  optimizing  C  compiler,  an  assembler,  a  linker,  an 
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archiver,  and  a  software  simulator.  Figure  (4-5)  illustrates  the  software  development 
flow  for  the  TMS320C30.  The  highlighted  area  shows  the  development  path  negotiated 
for  this  thesis. 
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Figure  4-5,  TMS320C30  software  development  flow  [Ref.  16]. 
The  tools  shown  in  Figure  (4-5)  perform  key  functions  in  the  software 
development  flow.  A  brief  description  of  each  tool  is  given  below.  Detailed  information 
is  found  in  References  [19,  20,  and  21]. 
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•  The  C  compiler  accepts  ANSI  standard  C  source  code  and  produces 
TMS320C30  assembly  language  source  code.  The  compiler  includes  an 
interlist  utility  which  interlists  the  C  source  statements  with  the  assembly 
language  output. 

•  The  assembler  translates  the  assembly  language  source  files  into  machine 
language  Common  Object  File  Format  (COFF). 

•  The  archiver  combines  a  collection  of  files  into  a  single  file  called  a  library. 
The  archiver  can  also  be  used  to  modify  the  existing  library  by  adding, 
replacing,  extracting,  or  deleting  members.  The  object  library  rts30.1ib  is 
included  with  the  C  compiler.  It  contains  standard  runtime-support  functions, 
compiler  utility  functions,  and  math  functions  that  can  be  called  from  C 
programs. 

•  The  linker  accepts  COFF  object  files  and  object  libraries  as  input  and 
combines  them  into  a  single  executable  object  module. 

•  The  object  format  converter  converts  the  COFF  object  file  into  either  TI- 
tagged,  Intel  hex,  Intel  word,  or  Tektronix  object  format.  The  converted  file  is 
then  downloaded  to  an  EPROM  programmer. 

•  The  simulator  is  a  software  program  designed  to  simulate  the  executable 
COFF  object  file  produced  by  the  linker.  The  simulator  allows  for  on-screen 
editing  and  shows  continuous  updates  as  you  step  through  the  code.  The 
simulator  also  features  multiple  windows  to  view  the  assembly  code,  CPU 
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registers  and  multiple  memory  locations.  A  complete  user's  guide  is  located 

in  the  NPS  power  lab  [Ref.  21]. 
As  shown  in  the  highlighted  portion  of  Figure  (4-5),  the  software  development  for 
this  research  started  at  the  assembly  language  level.  It  might  seem  that  given  the  choice 
of  writing  source  code  in  C  versus  assembly  language,  one  would  clearly  choose  writing 
the  code  in  C.  The  reason  for  starting  at  the  assembly  language  level  is  twofold.  First  of 
all,  NSWC  did  all  their  coding  in  assembly  language  and  although  this  code  did  not  have 
the  control  algorithms  for  the  SSCM  or  the  SSIM,  it  did  contain  all  of  the  initialization 
code  (explained  below)  for  the  Universal  controller.  The  time  constraint  place  on  this 
project  did  not  allow  for  the  reinvention  of  the  wheel,  so  much  of  the  NSWC  code  was 
used  for  the  initialization  of  the  board.  Secondly,  since  there  is  no  user's  manual  or 
documentation  for  the  Universal  Controller,  looking  at  the  assembly  code  and  the 
schematics  was  the  only  way  to  understand  how  the  board  operates  on  the  physical  level. 

1.  Texas  Instruments  Assembly  Code 

The  TMS320C30  instruction  set  contains  113  instructions.  Most  require  one 
clock  cycle  to  execute.  The  instruction  set  can  be  organized  into  the  following  five 
functional  groups: 

•  Load-and-store 

•  Two-operand  arithmetic/logical 

•  Three-operand  arithmetic/logical 

•  Interlocked  operations 
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•     Parallel  operations 
This  is  a  very  powerful  combination  of  instructions.  As  it  happened,  only  instructions 
contained  in  the  first  three  groups  were  used  for  this  research.  Reference  [16]  contains  a 
detailed  description  of  all  113  instructions. 

The  program  code  is  written  so  that  more  than  one  control  algorithm  can  be 
implemented  without  reprogramming  the  PROMs.  For  example,  the  NSWC  host  PC 
software  contains  a  menu  of  different  modes  to  choose  from  and  each  mode  required  a 
different  control  algorithm.  Each  control  algorithm  was  coded  on  the  same  PROM  as  a 
subroutine.    Figure  (4-6)  shows  the  general  flow  diagram  of  the  source  program.  The 
board  is  reset  and  initialized  by  turning  on  the  board's  power  supply.  Once  the  board  is 
initialized,  it  waits  for  an  interrupt  from  the  87C51  to  tell  it  what  to  do. 
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Figure  4-6,  General  flow  diagram  of  the  source  program 
The  initialization  of  the  board  can  be  broken  down  into  five  categories.  A  brief 
overview  of  each  category  is  described  as  follows: 
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a)  Initialize  Bus  Control 

The  TMS320  has  two  external  interfaces,  the  primary  bus  and  the 
expansion  bus.  Both  primary  and  expansion  buses  consist  of  a  32-bit  data  bus  and  a  set 
of  control  signals.  The  primary  bus  has  a  24-bit  address  bus  and  the  expansion  bus  has  a 
1 3 -bit  address  bus.       The  primary  bus  is  used  to  read  instructions  from  the  PROM  and 
read  and  write  to  the  SRAM  and  dual  port  memory.  The  primary  bus  must  generate  one 
wait  state  to  read  from  this  slower  memory.  The  primary  bus  also  must  also  be  set  to 
allow  for  1  M  bank  switching.  The  bank  switching  feature  of  the  primary  bus  provides  a 
period  of  time  for  allowing  the  PROM  and  SRAM  to  release  the  bus  during  the  dual  port 
memory  reads.  The  primary  bus  is  programmed  to  operate  as  discussed  above  by  writing 
428h  to  the  control  register  for  the  primary  bus  which  is  located  at  memory  location 
808064h. 

The  expansion  bus  is  connected  to  all  of  the  A/D  converters  and  counter/timers. 
To  allow  for  the  delay  associated  with  reading  and  writing  to  these  devices,  2  wait  states 
are  required  to  be  generated  by  the  expansion  bus.  The  expansion  bus  is  programmed  to 
operate  as  discussed  above  by  writing  48h  to  the  control  register  for  the  expansion  bus 
which  is  located  at  memory  location  808060h. 

b)  Initialize  stack  pointer 

The  stack  pointer  is  a  32-bit  register  that  contains  the  address  of 
the  top  of  the  system  stack.  This  address  is  the  location  in  memory  that  register  values 
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are  pushed  to  during  an  interrupt.  The  stack  pointer  is  initialized  to  809F00h  which  is 
located  in  one  of  the  internal  RAM  blocks. 

c)  Initialize  counter/times 

As  introduced  in  Chapter  III,  there  are  four  counter/timers  situated 
on  the  I/O  board.  Figure  (3-7)  illustrates  that  each  PLD  has  its  own  counter/timer  (C/T) 
connected  to  it  along  with  C/Tl .  Also  recall  that  each  C/T  has  three  counters  and  these 
counters  can  be  configured  to  operate  in  different  modes.  C/Tl  is  called  the  switching 
frequency  timer.  The  switching  frequency  counter  is  programmed  so  that  all  three 
counters  operate  as  a  divide  by  N  counter  (mode  2  as  referred  to  in  Ref.  [22]).  Figure  (4- 
7a)  shows  the  operation  of  mode  2.  In  this  mode,  when  a  count  N  is  written  to  the 
counter  control  register,  the  output  of  the  counter  stays  high  forN-1  counts  (recall  that  1 
count  is  100  ns)  and  goes  low  for  the  last  count  before  repeating  the  cycle.  The  PLDs  are 
programmed  to  generate  an  interrupt  when  the  output  of  the  counter  goes  low  and  these 
interrupts  will  be  used  to  implement  the  control  algorithm. 

The  other  three  C/Ts  are  programmed  as  hardware  retriggerable  one  shot  timers 
(mode  1  in  Ref.  [22]).  While  all  three  counters  on  each  of  these  C/Ts  are  set  up  in  mode 
1,  only  counter  2  is  used  to  generate  the  duty  cycle  for  both  the  SSCM  and  SSIM.  Figure 
(4-7b)  shows  the  operation  of  mode  1.  The  output  of  the  mode  1  counter  is  "high"  until 
the  gate  input  of  the  counter  senses  a  rising  edge.  This  triggers  the  counter  and  causes 
the  output  of  the  counter  to  go  "low"  for  a  count  of  M.  M  can  be  written  to  the  counter  at 


52 


any  time  and  can  be  changed  at  any  time;  however,  writing  a  new  M  value  during  the  low 
output  interval  will  not  change  the  current  count. 
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Figure  4-7,  (a)  Mode  2  divide  by  N  counter,  (b)  Model  hardware  retriggerable  one  shot. 

The  counter/timers  are  configured  by  calling  a  subroutine  called  initct.  An 
example  of  this  will  be  illustrated  in  Chapter  V.  This  subroutine  is  listed  in  Appendix  D. 

d)  Initialize  memory  pointers 

There  are  eight  32-bit  auxiliary  registers  (ARO  -  AR7)  that  can  be 
accessed  by  the  CPU.  The  primary  function  of  the  auxiliary  registers  is  the  generation  of 
24-bit  addresses.  Part  of  the  board  initialization  is  to  set  up  four  of  these  registers  as 
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permanent  memory  pointers  to  frequently  accessed  memory  blocks.  Table  (4-1)  shows 
the  memory  mapping  for  these  registers. 


Register 

Memory  Block 

Address 

AR3 

Pointer  for  Internal  Memory  Block  1 

809C00  hex 

AR4 

Pointer  for  Dual  Port  Memory 

100000  hex 

AR5 

Pointer  for  Internal  Memory  Block  0 

809800  hex 

AR7 

Pointer  for  SRAM 

80000  hex 

Table  4-1,  Initialized  address  pointers. 


e)  Enable  87C51  interrupt 


After  all  of  the  above  initialization  has  taken  place,  the  following 


two  lines  of  code  enable  the  87C51  interrupt. 


LDI      0008HJE 


OR       02000H,ST 
The  first  statement  sets  the  87C51  interrupt  bit  in  the  TMS320C30's  Interrupt  Enable 
Register.  Table  (4-2)  shows  the  9  least  significant  bits  of  the  IE  register  and  the 
associated  interrupt  for  each.  By  writing  0008H  to  this  register,  bit  3  becomes  set.  The 
second  statement  sets  the  Global  Interrupt  Enable  bit  (bit  13)  in  the  TMS320C30's  Status 
Register.  This  bit  must  be  set  or  the  C30  will  not  respond  to  any  interrupts,  even  if  they 
are  enabled  in  the  IE  register. 
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Once  the  87C51  interrupt  has  been  enabled,  the  initialization  process  is  complete. 
Appendix  D  contains  the  complete  listing  of  the  assembly  code  for  operating  the  SSCM 
and  SSIM. 
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;ister  and  their  associated  interrupt. 

2.  Texas  Instruments  C  Compiler 

As  stated  earlier,  the  software  development  tools  include  a  C  compiler  that 
produces  TMS320C30  assembly  source  output.  This  allows  the  programmer  to  write  the 
entire  program  in  C  or  intermix  C  functions  and  subroutines  with  an  assembly  language 
program. 

The  C  compiler,  along  with  all  the  TMS320  development  software,  is  installed  on 
the  DOS  computer  #M051273  in  BU-1 14.  The  compiler  is  called  up  by  typing  cl30  on 
the  command  prompt  in  the  DSPTOOLS  directory.  Complete  instructions  on  how  to 
compile  TMS320  C  programs  is  contained  in  Reference  [19]. 

Now  that  the  Universal  Controller  has  the  software  and  firmware  required  to 
initialize  the  board  as  explained  above  and  the  ability  to  receive  commands  and 
parameters  from  the  host  PC,  a  program  must  be  developed  to  implement  an  SSIM  or 
SSCM  control  algorithm.  The  development  of  this  code  is  discussed  in  the  next  chapter. 
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V.         DSP  CONTROL  IMPLEMENTATION 

A.  INTRODUCTION 

After  the  Universal  Controller  is  initialized  as  described  in  Chapter  IV,  the 
TMS320C30  waits  for  an  interrupt  from  the  host  PC  to  communicate  the  desired 
operating  mode.  Once  it  knows  what  mode  to  operate  in  it  will  perform  the  desired 
control  algorithm.  The  mode  setting  is  nothing  more  than  a  pointer  to  a  subroutine  that 
implements  the  control  algorithm.  This  chapter  first  includes  documentation  on  how  the 
DC-to  DC  converter  control  algorithm  was  implemented  using  the  Universal  Controller. 
Secondly,  a  description  of  NSWC's  ARCP  open-loop  control  implementation  and  an 
outline  of  the  modifications  required  to  implement  closed-loop  control  are  presented. 

B.  DC-TO-DC  CONVERTER  DSP  CONTROL  IMPLEMENTATION 

The  following  control  algorithm,  introduced  in  Chapter  II,  is  the  control  law 
implemented  on  the  3  kW  converters  located  in  the  Power  Systems  Laboratory  at  NPS: 

d(t)  =  Dss-(hv  +hn  \dt)(v0-vre/)-hXiL  -i0)  (5-1) 

where, 

d(t)  =  time-varying  duty  cycle  Dss  =  steady-state  duty  cycle  =  Vre/Vin(t) 

h,,  =  voltage  gain  h,,  =  integrator  gain 

v0  =  buck  output  voltage  h;  =  current  gain 

vref  =  reference  voltage  i0  =  load  current 

iL  =  inductor  current  Vjn(t)  =  input  voltage 
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The  only  difference  between  Equation  (5-1)  and  Equation  (2-4)  is  the  io/10  term.  This 
term  is  required  for  paralleling  two  units  and  since  the  3  kW  converters  are  stand-alone 
converters  they  will  not  be  required  to  operate  in  parallel. 

Equation  (5-1)  must  be  implemented  digitally.  To  do  this,  the  following  discrete 
terms  must  be  defined: 

•  Vin[nl>  Vout[n],  iout[n],  and  iL[n]  are  the  input  voltage,  output  voltage,  output 
current,  and  inductor  current  respectively  sampled  during  switching  period 
[n]. 

•  Vref  is  the  desired  output  voltage  and  can  be  entered  into  the  program  via  the 
host  PC  Settings  window. 

•  Dss[n]  is  the  steady-state  duty  cycle  calculated  during  the  current  switching 
period  using  the  following  equation: 

Dssfn]^  (5-2) 

•  vd[n]  and  vdint[n]  are  the  voltage  error  and  the  integral  of  the  error  calculated 
during  switching  period  [n].  The  voltage  error  is  simply  the  output  voltage 
minus  the  reference  voltage  as  shown  in  Equation  (5-3).  The  integral  of  the 
error  will  be  examined  below. 

Vd[n]  =  Vout[n]  -  Vref  (5-3) 

•  vd[n-l]  and  vdin,[n-l]  are  the  voltage  error  and  the  integral  of  the  error 
calculated  during  the  previous  switching  period,  [n-1]. 

•  d[n+l]  is  the  duty  cycle  for  the  next  switching  period. 
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The  integration  term  is  calculated  using  the  trapezoid  integration  method.  While 
other  integration  methods  can  be  used,  this  method  was  selected  because  it  appeared  to  be 
the  simplest  numerically.  Figure  (5-1)  shows  two  consecutive  discrete  values  of  vd .  The 
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Figure  5-1,  Trapezoid  integration, 
approximation  of  the  integral  is  established  by  connecting  the  two  points  with  a  straight 
line  and  identifying  the  area  of  the  resulting  trapezoid  and  then  adding  this  quantity  to  the 
prior  integration  error.  This  is  illustrated  in  the  following  equation: 


vdin,  [n]  =  vdint  [n  - 1]  +  -(vd  [n  - 1]  +  vd  [n]) 


(5-4) 


Using  the  above  approximation  for  the  integral  term,  Equation  (5-1)  becomes: 

d[n  +  l]=D^n]-hv(vout[n]-Vref) 

-hn{|(vd[n-l]  +  v4«])  +  vdlnt[n-l]|-h,(/L[n]-/out[n]) 
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It  is  clear  from  the  above  equation  that  only  the  integration  term  requires  two 
memory  states  in  its  calculation.  All  of  the  other  terms  require  only  the  current  sampled 
values. 


1. 


Control  of  One  DC-to-DC  Converter 


Controlling  one  buck  converter  requires  the  following  I/O  board  hardware  devices 
to  be  active:  two  PLDs,  two  counter/timers,  four  A/D  converters,  and  one  optical 
transmitter  as  illustrated  in  Figure  (5-2).    The  A/D  converters  are  required  to  convert  the 
sensed  voltages  and  currents  to  digital  form.  The  PLDs  and  counter/timers  generate  the 
switching  frequency  and  duty  cycle  to  be  transmitted  by  the  optical  transmitter  to  the  gate 
driver  circuit  on  the  buck  converter.  This  hardware  is  configured  after  the  C30  receives 
the  "DC-to-DC  Buck"  mode  command  from  the  host  PC. 


1  optical  transmitters  used     ►     /K/\./*kX\         AAAa         /\/X/\ 

INT 


PLDB 


^^ 


O.T 


INTO 
1 


r*         PLDA 


err  2 


C/T1 


-analog  inputs  used 


Figure  5-2,  Active  hardware  components  on  I/O  board  for  controlling  one  buck. 
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Chapter  IV  documented  how  the  Universal  Controller  was  initialized.  The  last 
step  in  this  initialization  process  was  to  enable  the  87C51  interrupt.  This  interrupt  is  used 
to  communicate  to  the  controller  what  mode  to  operate  in.  By  following  the  procedure 
developed  in  Chapter  IV,  selecting  the  DC-to-DC  Buck  mode  will  interrupt  the  C30  and 
execute  the  following  interrupt  service  routine: 

LDI  @dp_cint,IRO 

LDI  *+AR4(IR0),R0 

CALL  readcmd 

ANDN  mask_int3,IF 

These  four  lines  of  code  are  what  start  the  controller. 

The  first  two  lines  clear  the  87C51  interrupt  caused  by  the  host  PC.  IRO  is  an 
index  register  used  for  indirect  addressing.  The  contents  of  memory  location  dpcint 
(which  stands  for  dual  port  clear  interrupt)  is  loaded  into  IRO.  Recall  that  AR4  is  the 
pointer  for  the  dual  port  memory  (Table  4-1).  By  reading  the  memory  location 
*+AR4(IR0)  the  interrupt  to  the  87C51  caused  by  the  host  PC  will  clear,  which  will 
allow  for  future  host  PC  interrupts.  The  CALL  instruction  invokes  the  subroutine 
read_cmd.  This  is  the  subroutine  that  reads  the  dual  port  memory  location  that  contains 
the  mode  selected  (for  instance  DC-to-DC  Buck)  and  appropriately  configures  the  I/O 
board  (as  shown  in  Figure  (5-2)).  After  the  readcmd  subroutine  is  finished,  the  last  line 
of  code  clears  the  interrupt  flag  to  allow  for  future  87C51  interrupts. 

The  read_cmd  subroutine  retrieves  an  integer  from  the  dual  port  memory  that 
corresponds  to  the  desired  mode  entered  in  from  the  PC.  For  example,  when  the  DC-to- 
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DC  Buck  mode  is  selected,  an  integer  value  of  10  is  written  to  memory  location  10000 In 
within  the  dual  port  memory.  The  program  reads  this  value  from  the  dual  port  memory 
and  uses  this  number  to  branch  to  the  location  in  the  program  that  configures  the 
controller  for  DC-to-DC  Buck  mode. 

The  location  in  the  program  for  DC-to-DC  Buck  mode  is  labeled  "cmdlO:"  and  a 
listing  can  be  found  along  with  the  entire  program  in  Appendix  B.  Figure  (5-3)  illustrates 
the  program  flow  starting  with  the  87C51  interrupt.  It  is  this  portion  of  the  code  that 
configures  the  I/O  board  according  to  Figure  (5-2). 


wait  for  interrupt  int3 


0 


87C51  interrupt 
routine 


call   " 
return 


return  from  interrupt 


clear  interrupt 


read    cmd 


cmdlO 


call 


save_setup 


return 


call 


configure  startup 
ramp  fuction 


in  it   swct 


initialize  control 
variables 


enable 
interrupts 


Figure  5-3,  Program  flow  diagram  for  87C51  interrupt  routine. 
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The  first  task  includes  loading  the  parameters  that  were  stored  in  the  8-bit  word 
dual  port  memory  locations  (these  are  the  parameters  entered  from  the  Settings  window 
on  the  PC  software)  into  the  C30  internal  32-bit  memory  block.  This  is  done  in  the 
subroutine  savesetup.  This  subroutine  also  calculates  the  switching  period  in  terms  of 
number  of  counts  it  takes  the  switching  frequency  timer  to  count  up  to  the  switching 
period  time.  This  is  accomplished  by  dividing  the  desired  switching  period  by  the  period 
of  one  count  (100  ns)  on  the  counter/timer.  For  example,  if  the  desired  frequency  is  20 
kHz,  then  the  switching  period  in  counts  is  (50  |is)/(100  ns)  =  500  counts.  This  value  is 
stored  in  memory  location  tms_swp.  For  reasons  explained  below,  the  switching  period 
count  is  also  divided  by  two  and  stored  in  memory  location  tms_swp_120. 

The  next  task  performed  by  the  program  (shown  in  Figure  (5-3))  is  to  call 
subroutine  initswct.  This  subroutine  starts  the  switching  frequency  counter  timer,  C/Tl, 
by  storing  the  switching  period  count  (tms_swp)  in  the  counter(O)  register  and  counter(l) 
register.  Figure  (5-4)  depicts  the  configuration  of  this  process.  Before  loading  counter(2) 
with  tmsswp,  the  processor  waits  for  a  count  of  tms_swp_120  which  is  half  of  tmsswp 
as  explained  above.  The  reason  for  this  delay  will  become  clear  later.  Counter(O)  output 
is  inputted  into  PLD  A  and  causes  PLD  A  to  interrupt  the  C30  once  every  cycle  (intO). 
Likewise,  counter(l)  is  inputted  into  PLD  B  which  causes  interrupt  1  (intl)  to  occur 
between  the  PLD  A  interrupts.  These  interrupts  will  not  occur  until  the  intO  and  intl  have 
been  enabled  at  the  end  of  the  read  cmd  subroutine. 
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Figure  5-4,  The  switching  frequency  timer  is  configured  to  cause  PLD  interrupts. 
Following  the  program  flow  diagram  in  Figure  (5-3),  the  next  section  of  code 
configures  the  startup  ramp  function.  This  function  implements  a  linear  increase  in  the 
reference  voltage  to  avoid  large  current  and  voltage  oscillations  that  would  result  from  a 
large  step  in  Vref.  There  are  two  parameters  that  are  entered  from  the  Settings  window  that 
correspond  to  this  function.  These  parameters  are  STEP  and  DELAY  as  shown  in  the 
Settings  window  in  Figure  (5-5).  The  Step  parameter  is  the  number  of  voltage  steps 
desired  for  the  reference  voltage  ramp  from  0  to  Vref.  For  example  if  the  reference  voltage 
(desired  output)  is  208  volts  and  the  STEP  value  is  50,  the  reference  voltage  would  start 
at  0  volts  and  step  up  by  (208  modulus  50)  =  4  volts  every  DELAY  time  interval.  As 
implied  in  the  previous  statement,  the  DELAY  parameter  is  the  amount  of  time  the 
calculated  command  voltage  stays  at  a  given  level.  This  is  accomplished  by  using  one  of 
the  C30's  internal  timers  (timerO)  which  causes  an  interrupt  to  occur  after  each  delay 
count.  The  delay  count  is  calculated  by  multiplying  the  DELAY  parameter  by  1 00  and 
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then  storing  this  in  the  period  register  of  timerO.  Each  count  for  the  internal  timer  takes 
100  ns  (Tc)  so  if  the  desired  ramp-up  time  is  5  seconds  and  the  number  of  desired  steps  is 
50  the  DELAY  value  entered  at  the  Settings  window  should  be: 


DELAY 


ramp  up  time  5 

100(TC)(STEP)  ~  100*  100*1 0"9  *  50 


= 10000 


Once  Vref  reaches  the  desired  reference  voltage  the  timerO  interrupt  is  disabled. 
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Figure  5-5,  The  Settings  window  on  PC  software. 
The  next  step  in  the  listed  program  flow  is  to  initialize  the  control  values.  The 
following  parameters  from  the  Settings  window  must  me  modified  since  the  software 
limits  these  values  to  be  integers:  DC  VOLTAGE,  AC  SENSOR,  DC  SENSOR,  KC, 
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KCB,  and  BT.  DC  VOLTAGE  is  used  to  enter  the  reference  voltage  which  is  stored  as 
an  integer  and  must  be  changed  to  a  floating  point  value.  DC  SENSOR  and  AC 
SENSOR  are  the  conversion  factors  needed  to  convert  sampled  voltages  and  currents  to 
actual  values.  This  value  depends  on  the  scaling  factor  of  the  sensor.  For  example,  the 
voltage  sensor  for  the  3  kW  converter  has  a  voltage  divider  of  100:1  and  the  current 
sensor  implements  a  scaling  factor  of  10:1.  These  ratios  insure  that  the  limits  of  the  A/D 
converter  inputs  are  not  exceeded  given  that  the  maximum  input  voltage  does  not  exceed 
500  volts  and  the  maximum  current  does  not  exceed  50  amps.  Recall  from  Chapter  II 
that  the  output  of  the  A/D  converters  produce  12-bit  two's  complement  words. 
Therefore,  a  4.9975  volt  input  corresponds  to  a  01 1 1 1 1 1 1 1 1 1  lb  output,  and  a  -5  volt  input 
corresponds  to  a  100000000000b  output.  By  dividing  the  output  of  the  A/D  converter  by 
211  =  2048,  it  will  yield  a  value  between  [-1,1]  which  will  be  the  normalized  value  of  the 
actual  voltage  or  current.  Multiplying  this  by  5  will  give  the  voltage  at  the  input  of  the 
A/D  converter  and  then  multiplying  this  product  by  the  sensor's  scale  factor  will  yield  the 
actual  voltage.  The  values  that  must  be  entered  for  the  3  kW  converter  are  therefore: 

DC  SENSOR  =  5  *  100  -  500  (5-7) 

AC  SENSOR  =  5  *  10  =  50  (5-8) 

The  remaining  3  parameters,  KC,  KCB,  and  BT,  are  the  gains  used  in  Equation 
(5-5).  These  parameters  must  be  modified  since  the  PC  software  will  allow  only  integer 
values  between  1  and  60000.  A  derivation  of  the  small-signal  pole  locations  and  the 
resultant  control  gains  is  presented  in  Reference  [7].    The  desired  gains  and  the  required 
integer  values  that  must  be  input  at  the  Settings  window  are  listed  in  Table  (5-1).  The 
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last  column  of  Table  (5-1)  contains  the  scale  factor  that  is  used  to  convert  the  integer 
value  to  the  desired  value.  The  integration  term  (T/2)  in  Equation  (5-5)  is  collapsed  into 
the  gain  h,,  and  stored  in  memory  location  hn.  KCB  and  BT  are  stored  in  memory 
locations  hv  and  hi  respectively. 


Gain 

Parameter 

Desired  Value 

What  is  Entered 

Factor 

^ 

KC 

1.7333 

17333 

(T^IO"4 

hv 

KCB 

0.0008686 

8686 

io-7 

h, 

BT 

0.0105 

105 

io-4 

Table  5-1,  Gains  derived  in  Reference  [7]  and  its  associated  Settings  parameter. 

The  last  item  on  the  program  flow  diagram  illustrated  in  Figure  (5-3)  is  the  enable 
interrupts  block.  As  illustrated  in  Table  (4-2),  writing  OlOaH  to  the  Interrupt  Enable  (IE) 
register  will  enable  the  interrupt  PLD  B,  87C51,  and  timerO. 

The  87C51  interrupt  in  now  complete  and  the  Universal  Controller  is  ready  to 
start  the  ramp-up  and  the  closed-loop  control  (Equation  (5-5)).  Before  examining  how 
this  control  is  implemented  and  the  duty  cycle  varied,  some  discussion  is  required  on  how 
the  duty  cycle  is  produced. 

Figure  (5-2)  illustrates  that  one  optical  transmitter  is  used  transmit  the  duty  cycle 
to  the  converter  and  this  duty  cycle  is  generated  by  the  combination  of  PLD  A,  C/T2,  and 
C/Tl .  The  PLD  must  generate  an  inverted  duty  cycle  to  drive  the  optical  transmitter  so 
that  it  will  transmit  light  for  the  portion  of  the  duty  cycle  that  requires  the  switch  to  be 
closed.  This  prevents  the  converter  from  operating  (closing  the  switch)  if  the  Universal 
Controller  loses  power.  With  this  in  mind,  Figure  (5-6)  illustrates  how  the  count  in  the 
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counter(2)  register  of  C/T2  generates  the  "OFF"  portion  of  the  duty  cycle.  For  example, 
if  a  75%  duty  cycle  is  required  and  the  switching  frequency  is  20  kHz,  then  a  count  of  (1 
-  0.75)x(500  counts)  =  125  counts  must  be  written  to  the  counter(2)  register. 
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Figure  5-6,  PLD  A  generating  the  control  signal 
The  duty  cycle  is  varied  by  changing  the  count  value  in  the  counter(2)  register. 
The  control  algorithm  described  in  Equation  (5-5)  is  implemented  by  making  use  of  the 
PLD  B  interrupt.  Figure  (5-6)  shows  the  point  in  the  duty  cycle  where  the  PLD  B 
interrupt  occurs.  The  reason  for  placing  the  PLD  B  interrupt  in  the  middle  of  the  duty 
cycle  is  based  on  two  considerations.  The  first  consideration  is  the  time  needed  to  do  the 
required  calculations.  By  placing  the  interrupt  further  to  the  left  (earlier  in  the  cycle),  it 
will  allow  for  more  duty  cycle  calculation  time  (the  duty  cycle  must  be  calculated  before 
the  start  of  the  next  period,  see  Figure  (5-6)).  For  example,  given  a  switching  frequency 
of  20  kHz  and  PLD  B  interrupt  as  shown  in  Figure  (5-6),  the  time  given  to  calculate  the 
new  duty  cycle  (d[n+l])  is  limited  to  <  25  (as.  The  second  consideration  is  when  to 
sample  the  voltages  and  currents.  It  is  best  to  sample  these  signals  as  far  away  from  the 
switching  instant  as  possible  to  avoid  corrupting  the  samples  with  noise.  Although  the 
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duty  cycle  can  vary  between  [0,1],  the  steady-state  duty  cycle  is  «  70%  so  that  most  of 
the  switching  time  will  vary  between  [.5,1].  By  placing  the  interrupt  further  to  the  right 
(later  in  the  cycle),  it  will  reduce  the  chance  of  sampling  during  a  switching  event.  After 
taking  these  two  considerations  into  account  it  was  decided  to  place  the  PLD  B  interrupt 
in  the  middle  of  the  switching  period  as  shown  in  Figure  (5-6).  This  interrupt  time  can  be 
adjusted  by  changing  the  parameter  tms_swp_120  as  discussed  earlier. 

The  PLD  B  interrupt  will  occur  every  50  (o.s  (for  a  20  kHz  switching  frequency) 
and  it  will  trigger  an  interrupt  service  routine  that  implements  Equation  (5-5).  Figure  (5- 
7)  illustrates  the  PLD  B  service  routine.  As  mentioned  earlier,  the  routine  must  not  take 
more  than  25  |is  to  implement. 

The  first  task  indicated  in  the  flow  diagram  in  Figure  (5-7)  is  to  sample  the 
voltages  and  currents.  The  voltage  and  current  waveforms  that  are  to  be  sampled  are 
illustrated  in  Figures  (2-2)  and  (2-3).  With  the  switching  frequency  constant, 
theoretically  only  one  sample  per  cycle  is  needed  [Ref.  7]  to  implement  Equation  (5-5); 
however,  the  noise  associated  with  sampling  is  significantly  reduced  by  sampling  as 
many  times  as  possible  and  then  averaging  the  samples  over  one  switching  interval.  In 
Chapter  III,  it  was  shown  that  the  maximum  time  between  samples  for  the  A/D  converters 
is  2.95  (is.  Figure  (5-2)  shows  which  A/D  converters  are  used  and  the  physical  location 
on  the  I/O  board  used  to  connect  the  sensor  leads.  The  following  code  is  the  beginning  of 
the  PLD  B  interrupt  routine  and  initializes  an  A/D  conversion: 

LDI  @inputcs,AR0 

LDI  @acs,AR2 
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Figure  5-7,  Control  flow  diagram. 
The  inputcs  label  is  the  memory  location  that  contains  the  address  of  the 
converters  marked  on  the  I/O  board  as  J7  (input  voltage)  and  J8  (inductor  current).  The 
acs  label  is  the  memory  location  that  contains  the  address  of  the  other  two  A/D  converters 
marked  as  Jl  (output  voltage)  and  J4  (output  current).  Table  (5-2)  shows  the  address  and 
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labels  for  all  ten  A/D  converters.  The  first  two  lines  of  code  loads  (load  integer)  the 
inputcs  address  into  ARO  and  the  acs  address  into  AR2.  Since  the  data  bus  is  32-bits  wide 
and  each  A/D  output  is  only  1 2-bits  wide,  only  one  address  is  needed  to  read  two 
converters. 


Label 

Address 

XDO(LSB)  to  XDll(MSB) 

XD16  (LSB)  to  XD27  (MSB) 

acs 

804A00  hex 

Jl  (output  voltage) 

J4  (output  current) 

bcs 

804B00  hex 

J2 

J5 

CCS 

804C00  hex 

J3 

J6 

inputcs 

804900  hex 

J7  (input  voltage) 

J8  (inductor  current) 

adcl_cs 

804D00  hex 

Jl  1 

- 

adc2_cs 

804E00  hex 

- 

J12 

Table  5-2,  A/D  converter  addresses  and  labels. 
Recall  from  Chapter  III  that  the  A/D  converters  are  configured  such  that  a  LDI 
instruction  with  its  address  as  the  operand  will  not  only  read  into  the  destination  register 
(in  this  case  Rl  or  R2)  the  last  conversion  value  but  will  also  initiate  a  new  conversion. 
The  next  two  lines  of  code  initiate  the  conversion  of  the  sensed  analog  signal  to  a  digital 
signal  and  reads  the  previous  converted  signal.  Since  the  code  above  initiates  the  first 
A/D  conversions  of  the  interrupt  routine,  the  value  read  is  the  result  of  an  A/D  conversion 
that  took  place  in  the  previous  switching  period  and  therefore,  discarded.  The  conversion 
process  takes  2.95  u.s  so  to  get  the  results  of  the  current  conversion,  a  wait  loop  that  takes 
*  3.2  |is  to  run  is  applied.  The  wait  loop  contains  the  SUBI  (subtract  integer  which  takes 
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50  ns  to  execute)  and  the  BNZ  (branch  not  zero  which  takes  0.2  us  to  executed) 
instructions.  After  the  wait  loop  is  completed,  another  read  is  initiated  but  this  time  the 
signals  obtained  are  from  the  current  switching  period.  Table  (5-2)  lists  the  bits  of  the 
data  bus  associated  with  the  output  of  each  A/D  converter.  For  example,  the  instruction 

LDI  ARO,  R0 

loads  the  12-bit  digital  input  voltage  into  the  first  12-bits  of  register  R0  and  loads  the  12- 
bit  digital  inductor  current  into  bits  [16,27]  of  register  R0.  The  voltage  and  current  are 
separated  and  stored  in  separate  registers  with  the  following  code  [Ref.  16]: 

LDI  R0,R1 

LSH  04,R1 

ASH  -14h,Rl 

FLOAT  Rl 

LSH  14H,R0 

ASH  -14H,R0 

FLOAT  R0 

Figure  (5-8)  illustrates  how  the  above  code  separates  the  current  and  voltage  into 
separate  registers  and  converts  them  into  double  precision  floating  point  numbers.  After 
each  sample,  a  wait  loop  is  run  to  allow  another  sample  to  be  taken.  The  maximum 
number  of  samples  allowed  due  to  the  time  constraints  associated  with  a  20  kHz 
switching  frequency  is  5  samples.  This  was  determined  by  running  the  interrupt  code 
with  the  simulator.  After  5  samples  are  obtained,  the  samples  are  averaged  and  stored 
into  memory. 
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Figure  5-8,  Reading  the  A/D  output. 

The  flow  diagram  in  Figure  (5-7)  shows  that  the  next  task  is  for  the  program  to 
call  the  subroutine  mode  10.  Subroutine  mode  10  takes  the  averaged  samples  obtained 
above  and  calculates  the  duty  cycle  using  Equation  (5-5).  The  code  is  commented  and  is 
shown  in  Appendix  D.  After  the  new  duty  cycle  d[n+l]  is  calculated,  it  is  loaded  into 
register  R7. 

As  explained  earlier,  the  duty  cycle  is  the  number  of  counts  that  C/T2  counter(2) 
contains  in  its  register.  The  quantization  of  the  duty  cycle  is  defined  by  the  precision  of 
the  counter/timers.  The  smallest  amount  that  the  duty  cycle  can  change  is  by  1  count 
(100  ns)  which  corresponds  to  1/500  =  0.002  for  a  20  kHz  switching  frequency.  There 
are  limits  placed  on  this  count  number  based  on  the  logic  program  burned  into  the  PLDs. 
The  minimum,  in  terms  of  percent  of  the  switching  frequency  count,  is  5%  and  the 
maximum  is  95%.     Therefore,  if  the  calculated  duty  cycle  count  is  above  95%  of 
tmsswp,  R7  is  replaced  with  the  maximum  value.  Likewise  if  the  calculated  duty  cycle 
count  is  below  5%  of  tmsswp,  R7  is  replaced  with  the  minimum  value. 

There  is  a  comparator  circuit  on  the  I/O  board  that  that  will  send  a  "low"  signal  to 
the  each  PLD  if  any  signal  connected  to  J4,  J5,  and  J6  (from  Table  (5-2))  exceeds  the  AC 
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or  DC  trip  current  values  entered  from  the  Settings  window  (see  Figure  (5-5)).  The  PLDs 
could  be  reprogrammed  by  NS  WC  to  cause  all  the  switches  to  open  if  it  received  this 
"low"  overcurrent  condition.  Currently  this  capability  is  not  programmed  in  the  PLDs. 

Once  the  duty  cycle  has  been  determined  the  subroutine  mode  10  is  completed  and 
the  program  pointer  returns  to  the  PLD  B  interrupt  routine.  The  contents  of  register  R7  is 
then  stored  into  the  C/T2  counter(2)  register.  These  contents  are  stored  before  the  next 
trigger  from  C/Tl  as  shown  in  Figure  (5-5).    This  completes  the  PLD  B  interrupt 
subroutine  and  the  program  now  waits  for  the  next  interrupt. 


2. 


Control  of  Two  Converters 


The  Universal  Controller  can  control  two  buck  converters  with  only  a  slight 
modification  to  the  code.  Figure  (5-9)  shows  which  hardware  components  must  be 
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Figure  5-9,  I/O  board  configuration  for  controlling  two  buck  converters. 
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configured  on  the  I/O  board.  The  first  modification  includes  enabling  both  the  PLD  A 
and  PLD  B  interrupts.  This  is  done  by  modifying  the  last  step  in  the  87C51  interrupt 
shown  in  Figure  (5-3)  by  writing  OlObH  to  the  Interrupt  Enable  (IE)  register  which  will 
enable  the  interrupts  PLD  A,  PLD  B,  87C51,  and  timerO.  Since  both  buck  converters  will 
have  the  same  reference  voltage  and  control  gains,  no  other  modifications  to  this  part  of 
the  code  is  necessary. 

With  both  PLD  A  and  PLD  B  interrupts  enabled,  Figure  (5-7)  is  modified  so  that 
the  program  flow  diagram  looks  like  Figure  (5-10).  The  PLD  B  interrupt  routine  still 
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Figure  5-10,  Program  flow  diagram  for  controlling  two  buck  converters 
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samples  and  averages  the  currents  and  voltages  of  the  buck  converter  connected  to  PLD 
A  (buck  1).  Now  PLD  A  is  used  to  sample  the  voltages  and  currents  of  the  second  buck 
connected  to  PLD  B  (buck  2).  Figure  (5-4)  does  not  change;  therefore,  the  switching 
periods  will  be  synchronized  in  that  buck  2  will  start  its  switching  period  midway  into 
buck  1  's  switching  period.  The  model 0  subroutine  is  only  slightly  modified.  Since  each 
buck  has  a  different  voltage  error  (Vd)  and  integral  of  the  error  (Vdint),  these  variables  are 
updated  before  the  mode  10  subroutine  call  shown  in  Figure  (5-10).    The  mode  10 
subroutine  modifies  these  variables  and  uses  them  to  calculate  the  new  duty  cycle  for 
each  interrupt.  After  the  program  returns  from  the  mode  10  subroutine,  the  updated  Vd  and 
Vjjn,  values  are  stored  in  memory  to  be  used  for  the  next  duty  cycle  calculation. 

3.  Design  Development 

Much  of  the  design  development  involved  deciphering  how  the  Universal 
Controller  code  generated  a  fixed  duty  cycle.  The  task  was  cumbersome  since  the  only 
way  to  test  code  modifications  was  to  burn  the  code  into  the  PROMs  and  then  place  the 
PROMs  in  the  controller  and  check  to  see  if  it  worked. 

The  next  step  was  to  sample  signals  using  the  A/D  converters  and  then  convert 
these  digital  signals  to  the  proper  levels  for  application  in  the  control  algorithm.  A 
simple  feed-forward  controller  was  developed  to  aid  in  understanding  this  process.  The 
feed-forward  controller  simply  samples  the  input  voltage  and  a  duty  cycle  is  calculated 
using  only  the  Dss  term  (Equation  (5-1)). 
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Probably  the  most  difficult  task  involved  implementing  the  integrator.  Although 
the  trapezoidal  integration  technique  is  straightforward,  it  took  many  attempts  before 
learning  why  it  was  not  working  properly.  The  problem  was  simply  a  matter  of  not 
storing  the  sampled  signals  in  memory  before  using  them  in  calculations.  If  the  sampled 
signals  were  only  loaded  into  one  of  the  CPU  registers  and  not  stored  into  memory  the 
integrated  value  became  very  large.  Again  this  was  a  long  process  due  to  the  required 
PROM  burning  and  testing. 

4.  Results 

The  development  of  the  control  law  relied  on  digital  simulations  implemented 
using  the  Advanced  Continuous  Simulation  Language  (ACSL).  Reference  [7]  contains 
the  complete  development  of  the  control  law  including  simulation  development  and 
compares  the  simulated  results  with  the  actual  results.  Figure  (5-11)  shows  the 
simulation  results  for  a  periodic  change  in  load  from  10%  (291  W)  to  100%  (2.91  kW)  at 
a  frequency  of  20  Hz.  Both  the  output  voltage  (labeled  Vout3)  and  the  output  current 
(labeled  iout3)  are  plotted.  Figure  (5-12)  shows  the  actual  hardware  results  for  the  same 
periodic  load  change  with  the  3kW  buck  converter  using  the  Universal  Controller.  The 
plots  are  remarkably  similar.  The  output  voltage  in  Figure  (5-12)  is  AC  coupled  so  that 
the  plot  does  not  show  the  208  V  DC  value  that  the  variations  are  riding  upon.  As  a 
result,  the  noise  associated  with  the  sensing  devices  appears  more  pronounced  in  Figure 
(5-12). 
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Figure  5-11,  Simulation  results  for  10%  to  100%  change  in  load  [Ref.  7] 
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Figure  5-12,  Actual  results  using  the  buck  converter  and  Universal  Controller  [Ref.  7]. 
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C.  ARCP  INVERTER  DSP  CONTROL  IMPLEMENTATION 

The  Universal  Controller  was  initially  designed  by  personnel  at  NSWC  to  control 
an  ARCP.  The  firmware  provided  with  the  controller  contained  the  program  to  operate 
the  NSWC  ARCP  inverter  both  in  open  and  closed-loop  configuration.  For  this  reason, 
most  of  this  research  focused  on  implementing  the  DC-to-DC  converter  closed-loop 
control.  In  an  effort  to  not  reinvent  the  wheel,  the  NSWC  code  was  used  to  test  the 
PENN  State  ARCP  inverter  open-loop.  As  a  result  of  these  tests,  problems  with  the 
ARCP  hardware  were  discovered  and  consequently  this  delayed  the  investigation  of  the 
closed-loop  control  algorithm  for  the  ARCP.  The  remainder  of  this  chapter  contains  a 
discussion  of  the  firmware  developed  by  NSWC  for  open-loop  control  of  the  ARCP 
inverter  and  introduces  a  proposed  for  a  closed-loop  implementation. 

1.  NSWC  Open-Loop  Implementation 

Just  as  in  the  case  of  the  buck  converter,  the  I/O  board's  hardware  must  be 
configured  properly.  Figure  (5-13)  shows  the  I/O  board  hardware  that  is  used  to  operate 
the  ARCP  inverter  open  loop.  All  the  PLDs  and  counter  timers  are  used  to  generate  the 
switching  period  and  duty  cycle  signals  for  all  three  phases  of  the  ARCP  inverter.  Six 
optical  transmitters  are  used  to  send  an  "upper  switch"  and  "lower  switch"  gate  signal  to 
each  phase  of  the  inverter.  The  NSWC  code  must  be  burned  into  the  PROMs  and 
installed  on  the  Universal  controller  (Appendix  C  contains  the  location  of  the  code  and 
instructions  on  how  to  burn  the  PROMs).  Then  by  selecting  the  "Test  mode"  under  the 
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Mode  menu  item  on  the  PC  software,  the  controller  will  operate  the  ARCP  inverter  open 
loop. 


Figure  5-13,  I/O  board  configured  to  operate  the  ARCP  open  loop. 

While  the  "DC-to  DC  Buck"  selection  corresponds  to  cmdlO  and  mode  10,  the 
"Test  mode"  selection  corresponds  to  cmdl  and  model .  By  selecting  "Test  mode"  the 
PC  downloads  an  integer  value  of  one  to  memory  location  1 0000 1  h  within  the  dual  port 
memory.  The  readcmd  subroutine  then  reads  this  value  and  then  branches  to  the  portion 
of  code  associated  with  the  ARCP  open-loop  operation.  The  program  flow  is 
documented  in  Figure  (5-14)  and  is  similar  to  how  the  Universal  Controller  is  configured 
for  mode  10  as  shown  in  Figure  (5-3). 

The  flow  diagram  shows  that  there  are  three  subroutines  called  from  the  cmdl 
section  of  code.  The  savesetup  subroutine  is  very  similar  to  the  subroutine  used  in 
cmdlO.  It  loads  all  of  the  parameters  entered  from  the  Settings  window  on  the  PC  to  the 
internal  RAM  within  the  C30.  Just  like  the  setup  for  the  buck  converter,  the  parameter 

80 


tms  swp  is  calculated  and  unlike  the  buck  converter  the  parameter  tms  swp  120  is  set  to 
two-thirds  of  the  switching  period  count.  This  is  used  in  the  initswct  subroutine  and 
will  be  explained  below.  It  also  calculates  the  following  three  parameters  used  in 
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Figure  5-14,  Program  flow  for  the  open-loop  ARCP  operation, 
generating  the  PWM  signal: 


tms   ta  = 


tms_  swp 


(5-9) 


tms   tb  = 


tms_  swp  -  2{tms_  dt) 


(5-10) 
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tms_  stepx  = 


tms_  of  *  tms_  blk 
tms_ swf 


(5-11) 


where 


tmsswp  =  switching  period  count  calculated  in  save_setup  subroutine 
tmsdt  =  dead  time  entered  from  the  Settings  window 

tms_of=  desired  frequency  of  the  ARCP  output  entered  from  the  Settings  window 
tmsblk  =  block  size  of  the  sine- wave  table  entered  from  the  Settings  window 
tms_swf=  switching  frequency  entered  from  the  Settings  window 
The  above  equations  will  be  explained  later  in  the  chapter.  For  now,  it  suffices  to 
say  that  they  are  calculated  at  this  point  in  the  flow  diagram. 
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Figure  5-15,  Initializing  the  switching  frequency  timer  counters. 
The  initswct  subroutine  shown  in  Figure  (5-14)  is  also  the  same  subroutine  used 
for  the  buck  converter  except  that  the  value  of  tmsswp  120  is  different.  As  explained 
above,  the  save_setup  subroutine  calculated  this  value  to  be  two-thirds  of  the  switching 
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period  count.  So  each  counter  waits  this  many  counts  from  when  the  previous  counter 
started  before  starting  its  own  count  as  shown  in  Figure  (5-15).  This  causes  each  counter 
output  signal  to  be  separated  by  one-third  of  a  cycle  (120  degrees).  Thus,  this 
implements  the  desired  phase  displacement  required  in  a  balanced  3 -phase  system. 

The  next  task  indicated  in  Figure  (5-14)  is  for  the  program  to  call  the  subroutine 
sinetbl.  This  subroutine  simply  generates  one  period  of  a  sine-wave  using  the  following 
equation: 


a0  =  sin 


(5-12) 


tms_blk 
where 

N  =  is  an  integer  value  that  goes  from  0  to  (tmsblk-l)  in  unit  increments 
tmsblk  =  block  size  entered  from  the  Settings  window  on  PC 
R0  =  CPU  register  0 
Equation  (5-12)  is  implemented  in  a  loop  and  generates  a  lookup  table  which  is 
stored  in  the  SRAM.  The  length  of  the  lookup  table  is  tmsblk. 

The  last  step  indicated  in  the  program  flow  diagram  of  Figure  (5-14)  is  to  set  a 
pointer  for  phase  b  and  c.  The  pointer  for  phase  a  is  the  beginning  of  the  sine-wave 
lookup  table.  The  auxiliary  address  register  7  (AR7)  points  to  this  location.  Two  other 
variables  tms_23  and  tms_13  point  to  an  address  offset  from  AR7  by  \/3*tms_blk  and 
2/3*  tmsblk  respectively.  The  size  of  the  lookup  table  is  then  stored  in  the  block-size 
register  (BK)  which  is  used  for  circular  addressing  which  will  be  explained  below. 
Finally,  all  four  interrupts  (PLD  A,  PLD  B,  PLD  C  and  87C51)  are  enabled. 
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To  explain  how  the  PWM  signal  is  generated  from  the  above  equations  and  sine- 
wave  lookup  table,  it  is  best  to  consider  only  one  phase  at  a  time.  Figure  (5-16)  is  the 
flow  diagram  for  phase  a.  Just  like  the  buck  converter,  the  value  stored  in  the  counter(2) 
register  of  C/T2  will  determine  the  duty  cycle.  For  the  ARCP  the  duty  cycle  is  calculated 


using  the  following  equation: 


where 


duty  count  =  tms_tb  *  R7  +  tms_ta 

R7  =  value  read  from  the  sine- wave  lookup  table 
tmsta  =  Equation  (5-9) 
tmsjb  =  Equation  (5-10) 


(5-13) 


wait  for  interrupt       pld  A 


PLD  A  interrupt 
routine 


load  value  from 

sine-wave  lookup 

table 


CALL  model 


call 
return 


calculate  duty 
cycle 


load  duty  cycle 

into  C/T2"s 

counter(2) 

register 


return  from  interrupt 


clear  interrupt 


Figure  5-16,  PWM  signal  generation  for  phase  a. 
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Retrieving  the  sine-wave  value  from  the  table  is  accomplished  using  the  following  code: 

LDI  *+AR3(tms_stepx),  IR1 

LDF  *+AR7++(IRl)%,R7 

This  code  makes  use  of  the  circular  addressing  capability  of  the  C30  microprocessor. 
Circular  addressing  in  this  case  allows  the  pointer  to  the  lookup  table  to  be  incremented 
by  tmsstepx  (Equation  (5-11))  after  reading  the  current  memory  location  pointed  to  by 
AR7.  Once  IR1  reaches  the  value  stored  in  the  block-size  register  (BK),  the  pointer 
moves  back  to  the  beginning  address. 

This  code  is  executed  each  switching  period  and  for  a  20  kHz  switching  rate  that 
is  equivalent  to  every  50  |is.  Equation  (5-11)  yields  a  value  for  tmsstepx  that  will  allow 
the  above  code  to  cycle  through  the  lookup  table  in  the  desired  time  corresponding  to  the 
output  frequency.  For  example,  if  the  desired  output  frequency  of  the  ARCP  is  60  Hz, 
this  code  must  complete  one  circulation  of  the  lookup  table  in  16.7  ms  (1/60  s).  If  the 
block  size  of  the  lookup  table  is  2000  and  the  switching  frequency  is  10  kHz,  tmsstepx 
would  be  6  as  Equation  (5-11)  yields.  With  6  as  the  step  size,  it  would  take  2000/6=  333 
steps  to  cycle  through  the  lookup  table  and  at  50  \is  per  step,  it  would  take  333(50  u.s)  = 
16.7  ms  for  one  complete  cycle  which  is  the  desired  period  for  a  60  Hz  output. 

The  duty  count  as  shown  in  Equation  (5-13)  uses  Equations  (5-9)  and  (5-10). 
Figure  (5-17)  illustrates  how  the  PWM  signal  is  generated.  The  value  oftmsja  is  set  to 
half  of  the  switching  period  count,  as  explained  earlier,  so  that  when  R7  is  zero  (at 
location  a  in  Figure  (5-17))  the  duty  cycle  is  at  50%.  The  next  time  the  duty  count  is 
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calculated  R7  contains  the  value  from  the  sine-wave  lookup  table  found  at  location  b. 
Each  interrupt  the  duty  count  increases  until  R7  reaches  the  top  of  the  sine-wave  (at 
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Figure  5-17,  Generation  of  PWM  signal  using  Equation  (5-13). 
location  c).  From  here  the  duty  count  starts  to  decrease  and  returns  to  a  50%  duty  cycle 
as  shown  by  location  d.  The  duty  count  goes  below  a  50%  value  once  R7  starts  to  go 
negative  (at  location  e).  The  duty  count  reaches  its  minimum  value  when  R7  =  -1 
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(location  f)  and  returns  back  to  50%  as  shown  by  location  g.  The  amplitude  or  maximum 
duty  cycle  is  controlled  by  Equation  (5-10).  The  parameter  tmsdt  can  be  changed  from 
the  Settings  window  on  the  host  PC.  By  decreasing  this  value  the  amplitude  of  the 
control  sine-wave  increases.  The  minimum  tmsdt  allowed  is  14.  The  reason  for  this  is 
for  the  same  reason  the  buck  converter  duty  cycle  cannot  exceed  95%,  the  PLD  logic  will 
not  allow  a  100%)  duty  cycle. 

2.  Proposed  Closed-Loop  Implementation 

The  closed-loop  control  of  a  three-phase  inverter  may  be  implemented  in  a 
number  of  ways  including  sine-triangle  modulation,  bang-bang  hysteresis  control,  and 
space  vector  modulation  [Ref.  10].  Sine-triangle  PWM  is  attractive  from  the  standpoint 
that  the  harmonic  spectrum  is  well  understood  and  the  switching  frequency  is  fixed  by  the 
carrier  waveform.  The  control  signals  may  be  established  by  regulating  stationary 
reference  frame  quantities  or  synchronous  reference  frame  quantities.  The  advantage  of 
manipulating  synchronous  reference  frame  quantities  is  that  they  are  constants  in  the 
steady  state  so  that  the  integral  action  in  a  PI  controller  will  generate  zero  steady-state 
error.  In  order  to  regulate  synchronous  reference  frame  quantities,  we  need  to  convert  the 
measured  abc  quantities  to  the  synchronous  reference  frame  by  employing  a 
diffeomorphic  transformation.  At  which  point,  we  can  apply  the  PI  control  algorithm 
then  inverse  transform  those  quantities  and  retrieve  abc  control  voltages  required  by  the 
sine-triangle  PWM  control  [Ref.  10]. 
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In  this  research  effort,  it  was  decided  that  the  preliminary  closed-loop  control  for 
the  ARCP  would  regulate  the  currents  out  of  each  phase.  Currents  were  selected  as 
opposed  to  voltages  since  the  ARCPs  were  already  equipped  with  sensors  providing 
scaled  measurements  of  the  currents.  For  the  following  algorithm  description,  superscript 
V  will  denote  the  stationary  reference  frame,  superscript  'e'  will  denote  the  synchronous 
reference  frame,  subscripts  'abc'  will  denote  actual  phase  quantities,  subscripts  'qd'  will 
denote  transformed  quantities,  and  a  superscript '  * '  will  denote  a  commanded  value. 

The  algorithm  is  initiated  by  specifying  the  commanded  synchronous  reference 
frame  currents: 


ie  =  amplitude  of  desired  control 


*T=o 


(5-14) 


(5-15) 


Here  the  d-axis  commanded  current  is  arbitrarily  set  to  zero  for  convenience.  If  the  load 
is  a  three-phase  induction  machine,  then  this  commanded  value  may  be  fixed  at  some 
other  number.  To  calculate  the  stationary  reference  frame  currents,  two  of  the  three  phase 
currents  must  be  sampled  and  transformed  using  the  following  transformation: 


1  o 

V3         2>/3 


(5-16) 


where 


ia[n]  =  sampled  phase  a  current 
ib[n]  =  sampled  phase  b  current 
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The  above  equation  assumes  that  the  phase  currents  necessarily  sum  to  zero.  The 
next  task  is  to  transform  the  stationary  reference  frame  currents  to  synchronous  reference 
frame  currents  using  the  following  transformation: 


/;[»ll 


cos(0t[n])    -sin(0„[n])" 
in(0,[nj)     cos(0,[n]) 


sin 


(5-17) 


where 


0e  =  electrical  angle  of  the  desired  abc  quantities 
The  values  of  sin(#e)  and  cos(#e)  can  be  found  using  the  sinewave  lookup  table  in 
the  same  manner  as  in  the  open-loop  case  described  above.  The  PI  control  signals  are 
generated  using  the  commanded  synchronous  reference  frame  currents  in  Equations  (5- 
14)  and  (5-15)  and  the  calculated  synchronous  reference  frame  currents  in  Equation  (5- 
17).  Using  the  discrete  integrator  implementation  of  Equation  (5-4)  the  PI  control 


equations  becomes: 


T 


V;,/  M  =  KP,  (^  W)  +  KJ  /dint,q  [n  - 1]  +  - (/d,q  [n  - 1]  +  /d,q  [n]) 


(5-18) 


W/  [n]  =  KPd  K  W) +  Kic  W  [n  - 1]  +  - (/w  [n  - 1]  +  /d,d  [n]) 


where 


^    CM"'.!11] 


^.d        ld 


•W-'JH 

Kpq  and  Kpd  =  proportional  gains 
Kjq  and  Kid  =  integral  gains 


(5-19) 
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T 


'di»t,q  H  =  /d,„t,q  [n  - 1]  +  -  (j4q  [n  -  1]  +  /d,q  [n]) 


ldint,d 


T 
W  =  W  [n  -  1]  +  j  0'd,d  [n  -  1]  +  /d,d  [n]) 


Before  abc-control  signals  are  calculated,  the  control  signals  above  must  be 
inverse  transformed  back  to  the  stationary  reference  frame  using  the  following  inverse 


transformation: 


KM 
V<U4 


cos(0e[n])      sin(^[n])' 
-sin(0e[n])    cos(0e[n]) 


KA*] 


(5-20) 


The  stationary  reference  frame  voltages  are  then  used  to  calculate  the  abc-control  signals: 


V      =  Vs 

va,PI  vq,PI 


V      = 

v  U   DI 


b,PI 


V„DT  = 


C,PI 


.AVS     -^-W5 

ry      Vq,PI  ~  Vd,PI 


•V      -V 

va,PI  vb,PI 


(5-21) 

(5-22) 
(5-23) 


These  control  signals  are  translated  to  dutycount  for  each  phase  as  explained  in 
the  previous  section  using  Equation  (5-13).  The  following  dutycounts  are  then  written  to 
the  appropriate  counters: 


dutycount a  =  VaPI  *  Rl  +  tmsta 


(5-24) 


dutycount b  =  VbPI  *  Rl  +  tms_ta 


(5-25) 


dutycount c  =  Vc PI  *  Rl  +  tms_ta 


(5-26) 


where 


R7  is  a  CPU  register 
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tms_ta=  50%  of  switching  period  count. 
The  addresses  for  the  phase  counter/timers  are  shown  in  Figure  (3-3)  (ct_phasea, 
ctjphaseb,  and  ct_phasec).  The  following  code  illustrates  how  the  phase  a  counter/timer 
is  updated  with  the  new  duty  count  in  register  R7: 

LDI      @ct_phasea,AR.O 

STI       R7,*+AR0(2)  ;  Store  LSB  of  counter  2 


LSH     -08H,R7 


STI       R7,*+AR0(2) 


;  Store  MSB  of  counter  2 


The  steps  needed  to  go  from  open-loop  control  to  closed-loop  control  are  simply 
software  related.  The  PI  gains  and  the  desired  synchronous  reference  frame  commanded 
current  values  can  be  entered  from  the  Settings  window.  It  is  anticipated  that  once  this 
algorithm  is  successfully  implemented,  extensions  to  more  exotic  algorithms  and  electric 
machine  controls  will  be  quite  straight  forward. 
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VI.       CONCLUSIONS 

A.  SUMMARY  OF  RESEARCH  WORK 

The  Universal  Controller  was  designed  by  engineers  at  NSWC  and  populated, 
soldered  and  configured  at  NPS  by  the  Power  Systems  Group.  The  DSP  controller  allows 
for  greater  flexibility  in  control  implementation  which  enhances  the  research  efforts 
pertaining  to  the  DCZEDS  program.  The  focus  of  this  research  has  been  to  document 
how  the  Universal  Controller  works  and  then  apply  this  knowledge  to  implementing 
closed-loop  control  algorithms  for  a  buck  converter  and  a  3 -phase  inverter. 

In  Chapter  II,  the  basic  operation  and  specifications  for  the  3  kW  DC-to-DC 
converter  (SSCM)  and  the  30  kW  ARCP  Inverter  (SSIM)  were  discussed,  and  the 
motivation  for  using  DSP  control  was  addressed.  There  are  many  commercial  boards  that 
are  available  here  at  NPS,  and  in  Chapter  III  an  overview  of  these  boards  was  presented 
along  with  the  specific  limitations  that  made  them  unsuitable  for  application  in  SSCM 
and  SSIM  control.  Next,  the  hardware  that  makes  up  the  Universal  Controller  was 
described  and  investigated.  In  Chapter  IV  the  firmware  for  initializing  and  interfacing  all 
of  the  hardware  components  was  presented  along  with  the  basic  operation  of  the  primary 
components.  The  PC  software  which  interfaces  with  the  Universal  Controller  was  also 
described.    The  implementation  of  the  closed-loop  control  for  the  DC-to-DC  converter 
was  described  and  documented  in  Chapter  V.  Chapter  V  also  contains  an  explanation  and 
supporting  documentation  for  the  open-loop  control  of  the  ARCP  inverter.  Finally,  an 
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outline  of  the  modifications  required  to  implement  closed-loop  control  for  the  ARCP 
inverter  was  presented. 

B.  NOTABLE  CONCLUSIONS 

The  Universal  Controller  is  a  powerful  and  useful  tool.  The  hardware  is  uniquely 
setup  to  facilitate  controlling  not  only  the  SSIM  and  the  SSCM  but  many  other  PEBB 
applications.  The  closed-loop  control  implementation  for  the  DC-to-DC  converter 
yielded  acceptable  results  that  mirrored  those  obtained  for  simulation. 

There  were  a  number  of  limitations  discovered  while  analyzing  and  programming 
the  Universal  Controller.  One  of  these  limitations  includes  the  inability  to  program  a 
100%  duty  cycle.  While  this  was  not  a  problem  for  the  tests  that  were  conducted  in 
Reference  [4],  it  can  limit  the  dynamic  range  of  the  linear  control  and  introduce 
additional  harmonics.  Another  limitation  that  can  be  resolved  by  changing  the  logic 
within  the  PLDs  is  to  enable  the  PLD  to  shutdown  when  the  overcurrent  interrupt  occurs. 

C.  RECOMMENDATIONS  FOR  FUTURE  WORK 

Currently  all  the  programming  for  the  Universal  Controller  is  done  using  TMS320 
assembly  language.  The  program  is  then  burned  into  the  PROM  before  installing  it  on 
the  controller.  This  increases  the  development  time  to  test  and  debug  a  new  program. 
Writing  the  code  in  a  higher  level  language  like  C  would  make  it  easier  to  develop  and 
debug  new  or  modified  control  algorithms.  Another  time  saver  would  be  to  modify  the 
host  PC  software  to  allow  the  user  to  download  a  program  or  subroutine  into  memory 
without  reburning  the  PROM.  The  Settings  window  should  be  modified  or  a  new 
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Settings  window  for  the  buck  converter  added  to  facilitate  the  variables  unique  to  buck 
converter  control.  Other  recommendations  include: 

•  developing  the  ARCP  current  control  and  extending  it  to  voltage  control 

•  running  multiple  Universal  Controllers  from  one  PC 

•  investigating  other  buck  control  algorithms 

•  exploring  different  implementations  for  the  discrete  integration 

•  investigating  digital  filtering  of  signals  to  reduce  the  network  noise. 

The  Universal  Controller  is  an  integral  part  of  the  PEBB  vision.  The  advantages 
of  the  Universal  Controller  over  an  analog  controller  for  this  application  are  numerous. 
The  added  flexibility  that  this  controller  adds  to  the  DCZEDS  network  simulator  makes 
this  a  valuable  research  tool. 
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APPENDIX  A.  PARTS  LISTING  FOR  THE  UNIVERSAL  CONTROLLER 


Part# 

QTYIO 

QTY  CPU 

Part  Description 

C0110  95kll 

0 

1 

16  MHz  Clock 

C0110  95k08 

0 

1 

40  MHz  Clock 

VF 150  8840 

1 

0 

20  MHz  Clock 

IDT7130SA35P 

0 

1 

lkx8  dual-port  RAM 

D87C51FA 

0 

1 

microprocessor 

DM74AS373N-ND 

1 

1 

20-dip  octal  latch  w/  tri-state 

CY7C274-30WC 

0 

4 

32kx8  EPROM 

MC74HC14AN 

0 

1 

1 4-dip  Inverting  Schmitt  Trigger 

MM74HC08N-ND 

0 

1 

1 4-dip  quad  2-input  AND  gate 

TMS320C30GEL40 

0 

1 

DSP  chip 

IDT71256SA35P 

0 

4 

SRAM 

DM74AS244N-ND 

0 

1 

20-dip  octal  tri-state  buffer 

SN74LS244N 

4 

0 

Octal  buffers 

MM74HC244N-ND 

2 

0 

Octal  buffers 

SN74HC244N 

2 

0 

Octal  buffers 

EPM5016DC-15 

0 

1 

Programmable  Logic 

HP9429T1521 

12 

2 

Opto  Transmitter 

HP9507  R2521 

0 

2 

Opto  Receiver 
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Part# 

QTYIO 

QTY  CPU 

Part  Description 

AD536AJD 

6 

0 

RMS  to  DC  Converter 

LF347BN-ND 

4 

0 

14-dip  quad  JFET  op  amp 

HA- 1-4900-8 

2 

0 

Precision  quad  Comparator 

LF13508D-ND 

1 

0 

1 6-dip  8-Channel  JFET  Analog 
Multiplexer 

MAX120CNG-ND 

11 

0 

12-bit  AD  Converter 

AD7247JN 

1 

0 

AD  Converter 

CD74HCT377E 

5 

0 

Octal  D-Type  F-F  w/  Data  Enable 

DM7427N-ND 

1 

0 

14-dip  triple-input  NOR  gate 

CD74HCT32E 

2 

0 

14-dip  quad  2-input  OR  gate 

DM74AS04N-ND 

1 

0 

14-dip  hex  inverter 

CD74HCT138E 

1 

0 

1 6-dip  3-to-8  line  decoder 

CP82C54-12 

4 

0 

Programmable  Interval  Timer 

CD74HCT154E 

1 

0 

24-dip  4-to-16  line  decoder 

EPM5032  DC-25 

3 

0 

Programmable  Logic  (?) 

SN74LS93N 

1 

0 

4-bit  Binary  Ripple  Counter 

96  sock  conn 

0 

1 

3-row  96-pin  straight  connector 

96  plug  conn 

1 

0 

ditto 

12-pin  jump 

0 

1 

12-pin  jumper 

2-pin  jump 

0 

2 

2-pin  jumper 
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Part# 

QTYIO 

QTY  CPU 

Part  Description 

1 6-pin  strai  conn 

1 

0 

same 

10-pin  strai  conn 

1 

0 

same 

34-pin  strai  conn 

1 

0 

same 

5pos  DIP  sw 

1 

0 

same 

SW403-ND  sw 

0 

1 

Momentary  Switch 

P4887-ND.luF 

30 

14 

same 

47uF  (50V) 

2 

0 

same 

pl259-ND  lOOuF 

2 

0 

same 

pl255-ND  lOuF 

0 

1 

same 

p2101-ND22uF 

11 

0 

same 

p2063-ND  4.7uF 

6 

0 

same 

22k  8-pin  Res 

0 

3 

same 

2.2k  10-pin 

1 

0 

same 

330  16-pin 

2 

0 

same 

82k  resistor 

0 

1 

same 

1 5k  pot  resis 

1 

0 

same 

1  Ok  resistor 

4 

0 

same 

2.2k  resistor 

1 

1 

same 

330  resistor 

0 

2 

same 

270  resistor 

0 

2 

same 
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Part# 

QTYIO 

QTY  CPU 

Part  Description 

Green  LED 

0 

1 

same 

Red  LED 

0 

1 

same 

61yr  IOBRD 

1 

0 

same 

CPUBRD 

0 

1 

same 

28pin  wd  sock 

0 

8 

same 

28pin  nar  sock 

3 

0 

same 

14pin  sock 

0 

1 

same 

20pin  nar  sock 

0 

1 

same 

40pin  wd  sock 

0 

1 

same 

48pin  wd  sock 

0 

1 

same 

1 8 1  pin  sock 

0 

1 

same 

Terminal  Blocks 

12 

1 

same 

5m  HFBR-PWS005 

12 

4 

Fiber-Optic  Cabling 
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APPENDIX  B.  SCHEMATICS  FOR  THE  UNIVERSAL  CONTROLLER 


Figure  B-l  -  CPU  board. 
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Figure  B-2  -  Analog  converters. 
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Figure  B-3  -  The  counter/timers  and  optical  transmitters. 
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Figure  B-4  -  The  comparator  circuit. 
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Figure  B-5  -  The  PLD  logic. 
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APPENDIX  C.  SOFTWARE  INSTALLATION 

A.         HOST  PC  SOFTWARE 

The  software  is  located  on  PCPWR7  in  the  Power  Systems  group  laboratory. 
There  are  five  files  located  in  the  c:\PebbUC\hostpc  directory.  The  file  names  are: 

•  Pebb.exe 

•  Cmdialog.vbx 

•  Mscomm.vbx 

•  Spin.vbx 

•  Threed.vbx 

To  install  the  software  on  a  Window  3.1  machine  (this  will  not  work  in  Windows  95)  just 
load  all  the  vbx  files  under  the  c:\windows\system  directory  and  load  the  Pebb.exe  in  any 
directory. 

The  software  is  installed  on  the  only  Windows  3.1  machine  located  in  the  Power 
Systems  Group  Laboratory  #m051992.  The  Pebb.exe  is  installed  in  the 
c:\PEBB\win31new  directory. 

The  C++  code  that  generated  the  Pebb.exe  file  above  is  located  on  the  PCPWR7 
machine  in  the  c:\PebbUC\hostpc  directory  and  is  saved  as  a  C++  project  in  compressed 
format.  The  two  files  Pebb.zip  and  Pebbres.zip  are  written  in  Visual  C++  version  1.5  and 
will  not  work  with  version  4.0  (Windows  95). 
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B. 


INSTALLING  CODE  ON  THE  EPROMS 


There  are  two  different  assembly  codes  that  are  mentioned  in  this  thesis.  The 
code  received  from  NSWC  for  the  ARCP  (Pebbfix.asm)  and  the  code  developed  for  the 
buck  chopper  (npsbuck.asm).  Both  of  these  codes  are  stored  on  PCP  WR7  in  the 
c:\PebbUC\c30  directory. 

The  assembler  is  located  on  the  DOS  PC  #M051273  under  the  c:\DSPTOOLS 
directory.  There  are  many  files  in  this  directory  and  among  them  are  two  files  that  have 
been  setup  to  aid  in  the  assembly  process.  The  first  file  is  a  batch  file  called 
"NPSBUCK.BAT".  This  file  requires  the  input  file  name  (the  file  you  want  to  assemble) 
to  be  npsbuck.asm  and  that  it  resides  in  the  same  directory  it  is  in.     By  typing  "npsbuck" 
at  the  command  prompt  the  batch  file  will  do  the  following: 

•  assemble  the  npsbuck.asm  file 

•  link  the  output  object  file  produced  from  the  assembler  with  a  command  file 

•  convert  the  linked  file  into  Intel  hex  for  downloading  to  the  EPROM 

The  second  file  is  "NPSBUCK.CMD"  and  this  is  the  file  that  the  linker  uses  in  the 
batch  file  described  above.  The  contents  of  this  file  are  as  follows: 


math.obj  divi.obj 

-heap  0x800 

-m  npsbuck.map 

-e  init 

-o  npsbuck. out 

MEMORY 

{ 

VECS:  org  =  OOOOOh 

ROM:  org  =  00040h 

SRAM:  org  =  080000h 

DUAL_PORT:  org  =1  OOOOOh 

XBUS:  org  =  804000h 


length  =  0040h 
length  =  01  fcOh 
length  =  080000h 
length  =  080000h 
length  -  2000h 
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RAMI: 

org  =  809800h 

length  =  0400h 

RAM2: 
} 

org  =  809c00h 

length  =  0400h 

SECTIONS 

{ 

vecs: 

load  =  VECS 

.text: 

load  =  ROM 

.data: 

load  =  ROM 

sram: 

load  =  SRAM 

dualport: 

load  =  DUAL_PORT 

xbus: 

load  =  XBUS 

rami: 

load  =  RAMI 

ram2: 

load  =  RAM2 

} 

The  math.obj  and  divi.obj  are  subroutines  used  by  the  program.  The  subroutine  math.obj 
is  provided  by  Texas  Instruments  and  contains  many  math  functions  like  the  sine  function 
use  to  produce  the  sinewave  lookup  table.  The  divi.obj  is  a  subroutine  written  by  an 
engineer  at  NSWC  to  divide  integers. 

The  -heap  0x800  is  used  to  set  the  heap  size  for  the  C  memory  pool  command 
malloc()  to  800  words.  The  -m,  -e,  and  -o  are  linker  options  that  produce  a  map  listing  of 
the  output,  defines  a  global  symbol  that  specifies  the  primary  entry  point  for  the  output 
module,  and  specifies  the  name  of  the  output  file,  respectively. 

The  MEMORY  and  SECTIONS  headings  are  linker  directives.  The  MEMORY 
directive  allows  the  memory  to  be  configured  as  shown.  And  the  SECTIONS  directive 
controls  how  sections  are  built  and  allocated. 

The  output  will  consist  of  four  Intel  hex  files  NPSBUCK.I0,  NPSBUCK.il, 
NPSBUCK.I2,  and  NPSBUCK.I3.  These  are  the  files  that  must  be  downloaded  to  the 
four  EPROM  chips.  A  batch  file  named  CDU.BAT  is  located  in  the  same  directory  as  the 
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other  files  mentioned  above.  By  typing  cdu  at  the  prompt,  the  Universal  Programmer  and 
Tester  (EPROM  burner)  will  open.  The  Device  menu  item  will  be  highlighted.  Press  the 
D  key  and  a  drop  down  menu  will  be  shown.  Select  EPROM  from  this  dropdown  menu 
and  a  series  of  windows  will  ask  what  manufacturer  and  type  of  EPROM  you  have.  Once 
you  selected  the  desired  EPROM,  you  are  now  ready  to  load  the  hex  file  to  the  buffer.  To 
do  this  select  2  (Load  Bin  or  Hex  file  to  buffer)  from  the  selection  window.  The  window 
will  now  giver  you  the  directory  listing.  Find  the  c:\DSPTOOLS\NPSBUCK.I0  file  and 
highlight  it  and  press  enter.  The  program  will  then  prompt  you  for  file  type,  enter  "I"  for 
Intel  hex.  Next  it  will  ask  you  "file  start  seg.  (0000):"  just  hit  the  enter  key.  The  last 
prompt  will  ask  what  you  want  the  unused  bytes  to  be.  Enter  "1"  for  zeros,  and  then  hit 
the  enter  key.  Now  the  file  NPSBUCK.IO  is  loaded  into  the  buffer.  Place  a  blank 
EPROM  in  the  socket  on  the  programmer  module  and  enter  "A".  This  will  load  the 
program  into  the  EPROM.  When  it  is  done  loading  it  will  beep  and  then  you  should 
repeat  the  same  process  over  until  all  four  EPROMS  are  loaded.  The  EPROM  with 
NPSBUCK.IO  is  placed  in  socket  U5  on  the  CPU  board;  likewise  Ml  goes  in  U6,  *.I2 
goes  in  U8,  and  *.I3  goes  in  U9. 

C.         MICROCONTROLLER  SOFTWARE 

The  assembly  code  for  the  microcontroller  is  located  in  the  PCPWR7  computer  in 
the  c:\PebUC\87C51  directory.  The  assembler  for  this  device  is  on  the  same  machine  as 
the  host  PC  software  in  the  power  lab.  The  directory,  c:\Pebb\intel\compiler,  contains  the 
assembler  and  the  object  code  (.hex  extension)  in  the  format  accepted  by  the  EPROM 
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programmer.  This  file  must  be  copied  to  a  floppy  disk  and  then  transferred  to  the  DOS 
computer  to  be  loaded  into  the  buffer  of  the  programmer  in  the  same  manner  as  above 
except  that  the  device  picked  must  be  the  87C51 . 

D.         PROGRAMMABLE  LOGIC  DEVICES  (PLDs) 

There  are  two  PLD  programs  that  are  required  by  the  Universal  Controller.  One 
for  the  three  PLDs  that  generate  the  duty  cycle  and  the  other  for  the  address  decoder.  The 
PLD  code  is  located  in  the  c:\PebbUC\PLDs  directory.  The  files  have  the  "pof ' 
extension  which  means  they  are  in  the  format  needed  by  the  EPROM  programmer.  The 
duty  cycle  PLD  code  is  in  the  dcpld.pof  file  and  the  decoder  PDL  code  is  in  the 
decoder.pof  file.  To  program  this  into  the  chips,  copy  these  files  on  a  floppy  disk  and 
transfer  them  to  the  DOS  computer  to  be  loaded  in  the  program  buffer  of  the  programmer. 


Ill 
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APPENDIX  D.  ASSEMBLY  CODE  FOR  DC-TO-DC  CONVERTER 


* 

*  NPS  POWER  LAB 

*  TMS320C30  MODIFIED  CONTROL  CODE 

*  BY  RON  HANSON 

*  25  Feb  97 
* 

* 

.title     "BUCK" 


.global  reset,init 

.global  int0,intl,int2,int3 

.global  tintO 

.global  isr0,isrl,isr2,isr3 

.global  timeO 

.global  FPINV,divi 


.sect 

"vecs" 

reset 

.word 

init 

intO 

.word 

isrO 

intl 

.word 

isrl 

int3 

* 

.space  1 
.word 

isr3 

tintO 

.space 
.word 

4 
timeO 

.space 

34 

* 

.data 

sram 

.word 

0080000H 

blkO 

.word 

0809800H 

blkl 

.word 

0809C00H 

stck 

.word 

0809F00H 

Ctrl 

.word 

0808000H 

xbus 

* 

.word 

0000048H 

pbus 

.word 

0000428H 

;  Named  section 
RS-  loads  address  init  to  PC 
INTO-  loads  address  intO  to  PC 
INT1-  loads  address  intl  to  PC 

;  INT3-  loads  address  int3  to  PC 

;  Reserved  space 

;  Timer  0  interrupt  processing 

;  Reserved  space 


Beginning  address  of  SRAM 

Beginning  address  of  RAM  block  0 

Beginning  address  of  RAM  block  1 

Beginning  of  stack 

Pointer  for  peripheral-bus  memory  map 

Xpansion  bus:  2  wait  states,  external 

RDY  not  in  use  (88) 

;  Primary  bus  :  1 M  bank  compare,  1  wait 
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* 

timOctl 

* 

* 


.word    00003C1H 


;  states,  external  RDY  not  in  use 

;  Internal  timer  0:  11 1 1000001;  (301)  1100000001 


dpmem  .word 

dpint  .word 

dpcint  .word 

tmsoaci  .set 

tmsacv  .set 

tmsbdly  .set 

tmsbtime  .set 

tmsodci  .set 

tmsVref  .set 

tmsdt  .set 

tmsof  .set 

tms_swf  .set 

tmsblk  .set 

tmsacs  .set 

tms_dcs  .set 

tms_step  .set 

tms_delay  .set 

tms_swp  .set 

tmsstepx  .set 

tmsta  .set 

tmstb  .set 

tmskc  .set 

tmskcb  .set 

tmsbt  .set 

tmsbi  .set 

tmsmode  .set 
tms_swp_120  .set 

UMIN  .set 

UMAX  .set 

Vdiff  .set 

Vdint  .set 

hn  .set 

hv  .set 

hi  .set 

iL  .set 

iout  .set 

Vdiffa  .set 

Vdiffb  .set 


0 1 00000H  ;  Pointer  for  dual  port  memory  (command  reg) 

00003 FEH  ;  Pointer  for  setting  interrupt  flag 

00003 FFH  ;  Pointer  for  clearing  interrupt  flag 

000000 1 H  ;  Ac  trip  current  level 

0000002H  ;  test 

0000003H  ;  Boost  delay 

0000004H  ;  Boost  time 

0000006h  ;  Dc  trip  current  level 

0000007H  ;  Dc  voltage 

0000008H  ;  Deadtime 

0000009H  ;  Ac  frequency 

OOOOOOaH  ;  Switching  frequency 

OOOOOOcH  ;  Block  size 

OOOOOOdH  ;  current  sensor 

OOOOOOeH  ;  voltage  sensor 

OOOOOOfH  ;  Step 

000001  OH  ;  Delay 

00000 1 1 H  ;  Switching  period 

00000 12H  ;  Step 

00000 13H  ;ta  constant 

00000 14H  ;  tb  constant 

00000 1 5H  ;  Control  constant 

00000 1 6H  ;  Control  constant 

00000 1 7H  ;  Control  constant 

00000 1 8H  ;  Control  constant 

00000 19H  ;Mode 

00000 laH  ; 

00000  leH  ;  Minimum  duty  cycle 

00000 1  fH  ;  Maximum  duty  cycle 
0000020H  ;  Vout-Vref 
000002 1 H  ;  integral  of  Vdiff 
0000022H  ;  integrator  gain 
0000023H  ;  voltage  gain 
0000024H  ;  current  gain 
0000025H  ;  sensed  inductor  current 
0000026H  ;  sensed  output  current 
0000027H  ;  converter  a  Vdiff 
0000028H  ;  converter  b  Vdiff 
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Vdinta 

.set 

0000029H        ; 

Vd_intb 

.set 

000002aH        ; 

Vout 

.set 

000002fH        ; 

Vininv 

.set 

0000030H        ; 

vperfreq 

.set 

0000033H        ; 

stopfreq 

.set 

0000034H        ; 

stopvolt 

.set 

0000035H        ; 

tmstboost 

.set 

000003aH        ; 

tmsacscale 

.set 

000003bH        ; 

tms_dcscale 

.set 

000003cH        ; 

tmsoutputb 

.set 

000003eH        ; 

tmsilmin 

.set 

000003fH        ; 

tblsize 

* 

.set 

00000 laH        ; 

* 
ct_swfreg 

.word 

0804000H       ; 

ct_port 

.word 

0804 100H       ; 

ct_phasea 

.word 

0804200H       ; 

ct_phaseb 

.word 

0804300H        ; 

ct_phasec 

.word 

0804400H       ; 

doutput 

.word 

0804500H       ; 

inputcs 

.word 

0804900H       ; 

acs 

.word 

0804a00H        ; 

bcs 

.word 

0804b00H        ; 

CCS 

* 

.word 

0804c00H 

cmdad 

.int 

startcmd 

modead 

* 

.int 

modecmd 

mask_intO 

.set 

000000 1H 

maskintl 

.set 

0000002H 

mask_int2 

.set 

0000004H 

mask_int3 

.set 

0000008H 

mask  timerO 

.set 

0000100H 

converter  a  Vdint 
converter  b  Vd_int 
converter  output 
inverse  of  converter  output 
Volt  per  frequency  ratio 
Target  frequecy 
Target  voltage 

convert  current 
convert  voltage 


Setup  table  size 


Switching  frequency  timer 

Timer  control  register 

Phase  A  timer 

Phase  B  timer 

Phase  C  timer 

General  purpurse  digital  output  port 

Input  voltage  and  current  ADC 

Phase  a  output  voltage  and  current  ADC 

Phase  b  output  voltage  and  current  ADC 

Phase  c  output  voltage  and  current  ADC 


Set  external  interrupt  0  (isrO) 

Set  external  interrupt  1  (isrl) 

Set  external  interrupt  2  (isr2) 

Set  external  interrupt  3  (isr3) 

Set  internal  timer  0  interrupt 


clearmain       .word 
resetout  .word 

*  Define  constants 

swpconst        .word 
invllbits  .float 

mil  .float 


0004444H 
OOOffffH 


10000000 

0.00048828125 

0.001 
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en7 
en4 
AVE 
max 

min 

* 


.float 
.float 
.float 
.float 
.float 


0.0000001 

0.0001 

0.2 

0.95 

0.05 


cmd  .usect  "dualport",10000h 

ctio  .usect  "xbus",2000h 

lookup  .usect  "rami ",400h 

varible  .usect  "ram2",400h 

.text 
init:  LDI  0,DP 

LDI  00H,ST 

LDI  0000HJE 

LDI  @ctrl,AR0 

LDI  @xbus,R0 

STI  R0,*+AR0(60H) 

LDI  @pbus,R0 

STI  R0,*+AR0(64H) 

LDI  @stck,SP 

CALL  initct 

LDI  @d_output,AR0 

LDI  00FFH,R0 

STI  R0,*AR0 

LDI  @ct_port,AR0 

LDI  @reset_out,R0 

STI  R0,*AR0 

LDI  @ctrl,AR0 

LDI  @blkl,AR3 

LDI  @dp_mem,AR4 

LDI  @blk0,AR5 

LDI  @sram,AR7 

LDI  @dp_cint,IR0 

LDI  *+AR4(IR0),R0 

LDI  000H,R0 

RPTS  2047 

STI  R0,*AR4++(1) 

LDI  @dp_mem,AR4 

LDI  0000HJF 

LDI  0008HJE 

OR    02000H,ST 
begin:  NOP 

NOP 
NOP 


Point  the  DP  register  to  page  0 

Clear  and  enable  cache,  and  disable  OVM  (1800h) 

Clear  all  interrupts 

Load  peripheral  bus  memory-mapped  reg 

Init  expansion  bus  control  reg 

Init  primary  bus  control  reg 
Initialize  the  stack  pointer 
Init  counter/timer 


Pointer  for  counter/timer  control  register 

Disable  all  output 

Sratch  pad  memory  area 

Top  of  dual  port  memory 

Sratch  pad  memory  area 

Top  of  the  look  up  table 

Clear  dual  port  memory  interrupt 

Clear  sram  memory 


Top  of  dual  port  memory 

Clear  all  flags 

Enable  interrupt  3  (dual  port  memory) 

Global  interrupt  enable 
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NOP 

BR     begin 

* 

*  (NSWC  code) 

*  Initialize  counter/timer 

initct:  LDI  @ct_port,AR0 
LDI  00ffH,R0 
STI  R0,*AR0 
LDI  @ct_swfreg,ARO 
LDI  0034H,R0 
STI  R0,*+AR0(3) 
LDI  0074H,R0 
STI  R0,*+AR0(3) 
LDI  00b4H,R0 
STI  R0,*+AR0(3) 
LDI  @ct_phasea,ARO 


Pointer  for  counter/timer  control  register 

Disable  all  counter/timer  output 
Pointer  for  switching  frequency  timer  1 
Mode  2  (rate  generator),  001 10100B 

01110100B 

10110100B 


Mode  1,  R/W  LSB  &  MSB,  101 10010B 


Pointer  for  phase  a  counter 
LDI  00 1 2H,R0  ;  Mode  1  (hardware  retriggerable  one-shoot),  000 1 00 1 0B 

STI  R0,*+AR0(3) 

LDI  0052H,R0  ;  Mode  1 ,  R/W  LSB,  0 1 0 1 00 1 0B 

STI  R0,*+AR0(3) 
LDI  00b2H,R0 
STI  R0,*+AR0(3) 
LDI  @ct_phaseb,AR0  ;  Pointer  for  phase  b  counter 

LDI  0012H,R0  ;  Mode  1  (hardware  retriggerable),  R/W  LSB,  000 1001 0B 

STI  R0,*+AR0(3) 

LDI  0052H,R0  ;  Mode  1 ,  R/W  LSB,  0 1 0 1 00 1 0B 

STI  R0,*+AR0(3) 
LDI  00b2H,R0 
STI  R0,*+AR0(3) 
LDI  @ct_phasec,AR0  ;  Pointer  for  phase  c  counter 

LDI  0012H,R0  ;  Mode  1  (hardware  retriggerable),  R/W  LSB,  000 1001 0B 

STI  R0,*+AR0(3)  ; 

Mode  1,  R/W  LSB,  01010010B 


Mode  1,  R/W  LSB  &  MSB,  10110010B 


LDI  0052H,R0 
STI  R0,*+AR0(3) 
LDI  00b2H,R0 
STI  R0,*+AR0(3) 
RETS 

*(NSWC  code) 

*  Modified  25  Feb  97 

read_cmd:LDI    *+AR4(l),R0 
AND    00FFH,R0 
CMPI  01EH,R0 
BHS    stopinit 


;  Mode  1,  R/W  LSB  &  MSB,  101 10010B 


Check  command 
Clear  all  other  bits 

Ignore  command  if  command  >=  23 
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LDI    @cmd_ad,Rl 
ADDI  R1,R0 
BNZ    RO 
stopinit:  RETS 


startcmd:  BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdlO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
BR  cmdO 
RETS 


Off 


;  DC  to  DC  Buck 


♦Turning  off  ARCP 

*(NSWC  code) 

cmdO:     LDI  08HJE 

LDI  @ct_port,AR0 
LDI  @clear_main,RO 


Disable  interrupts  0, 1 ,2 

Pointer  for  counter/timer  control  register 
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STI  RO,*ARO  ;  Disable  all  output 

STI  R0,*+AR3(tms_outputb) 
LDI  030H,R0 
wait20:    SUBI01H,R0 
BNZ  wait20 
LDI  @reset_out,RO 
STI  R0,*AR0 
CALL  initct 
LDI  00H,R0 
STI  R0,*+AR4(1) 
LDI  @dp_int,IR0 
STI  R0,*+AR4(IR0) 
LDI  @d_output,ARO 
LDI  0FFFH,R0 
STI  R0,*AR0 
LDI  @ct_port,AR0 
LDI  @reset_out,RO 
STI  R0,*AR0 
RETS 


Disable  all  counter/timer  output 


Pointer  for  counter/timer  control  register 
Disable  all  output 


*  DC  to  DC  Buck  Converter 
*(NPS  code  5  May  97) 
cmdlO:LDI  08H,IE 

LDI    @ct_port,AR0 

LDI    @clear_main,RO 

STI    R0,*AR0 

LDI    030H,R0 
wait210:  SUBI  01H,R0 

BNZ    wait210 

LDI    @reset_out,RO 

STI    R0,*AR0 

CALL  initct 

CALL  save_setup 

CALL  init_swct 

LDI    *+AR3(tms_swp),R0 

FLOAT  RO 

LDF   @max,Rl 

MPYF  R0,R1 

STF    R1,*+AR3(UMAX) 

MPYF  @min,R0 

STF    R0,*+AR3(UMIN) 

LDI    *+AR3(tms_Vref),R0 

FLOAT  RO 

RND  RO 


Disable  interrupts  0,1,2 

Pointer  for  counter/timer  control  register 

Disable  all  output 


Disable  all  counter/timer  output 

Save  data  in  32-bit  format 

Init  switching  frequency  counters 
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STF    R0,*+AR3(tms_Vref) 
start  up  ramp  function 


LDI    *+AR3(tms_step),R0 
STI    R0,*+AR3(stopfreq) 
LDI    000H,R0 
STI    R0,*+AR3(tms_stepx) 
LDI    *+AR3(stopfreq),R0 
FLOAT  RO 
CALL  FPINV 

MPYF  *+AR3(tms_Vref),R0 
RND  RO 

STF    R0,*+AR3(vperfreq) 
LDF  0000,R0 
STF    R0,*+AR3(tms_Vref) 
LDI    @ctrl,AR0 
mapped  reg 

LDI    *+AR3(tms_delay),R0 

MPYI  064H,R0 

STI    R0,*+AR0(28H) 

LDI    @tim0ctl,R0 

STI    R0,*+AR0(20H) 


Startup 


Load  peripheral  bus  memory- 


Init  internal  timer  0 


voltage  and  current  scaling 


LDI    *+AR3(tms_dcs),R0 

FLOAT  RO 

MPYF  @invllbits,RO 

RND  RO 

STF    R0,*+AR3(tms_dcscale) 

LDI    *+AR3(tms_acs),R0 

FLOAT  RO 

MPYF  @invllbits,RO 

RND  RO 

STF    R0,*+AR3(tms_acscale) 


*  define  hi,  hn,  hv  and  T/2 


LDI 

*+AR3(tms  swf),R0 

RO  =  fsw 

FLOAT 

RO 

MPYF 

2.0,R0 

RO  =  2*  fsw  =2*fsamp 

CALL 

FPINV 

R0=1/R0 

LDI 

*+AR3(tms_kc),Rl 

, 
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FLOAT            Rl 

MPYF  @en4,Rl 

hn 

MPYFR1,R0 

RND                RO 

STF                  R0,*+AR3(hn) 

hn*T/2 

LDI                  *+AR3(tms_kcb),R0 

FLOAT            RO 

MPYF  @en7,R0 

RND                RO 

STF                  R0,*+AR3(hv) 

;hv 

LDI                  *+AR3(tms_bt),R0 

FLOAT            RO 

MPYF  @en4,R0 

RND                RO 

STF                  R0,*+AR3(hi) 

hi 

LDF                 0.0,R0 

STF                  R0,*+AR3(Vdiffa) 

Initialize  Vdiff 

STF                  R0,*+AR3(Vd_inta) 

Initialize  Vdint 

STF                  R0,*+AR3(Vdiffb) 

Initialize  Vdiff 

STF                  R0,*+AR3(Vd_intb) 

Initialize  Vdint 

LDI    @ctjport,AR0 

;  Pointer  for  counter/timer  control  register 

LDI    00300H,R0 

;  1100000  (disable  phase  C) 

STI    R0,*AR0 

;  Enable  all  counter/timer  output 

STI    R0,*+AR3(tms_outputb) 

LDI    OlObHJE 

,  Enable  interrupts  0,1,3,8 

LDI    01H,R0 

STI    R0,*+AR4(1) 

LDI    @dp  int,IR0 

STI    R0,*+AR4(IR0) 

RETS 

*(NSWC  code)  Modified  5  May  97 

savesetup:  LDI  tblsize,RC 

;  Init  loop  counter 

RPTB  save_dp 

5 

LDI    *AR4++(1),R0 

;  Start  at  the  top  of  the  dual  port  memory 

AND    0ffH,R0 

;  Mask  out  all  higher  bits 

LSH    08H,R0 

;  Rotate  8  bits  to  the  left 

LDI    *AR4++(1),R1 

;  Get  LSB 

AND    OffH,Rl 

OR     R0,R1 

save_dp:  STI    R1,*AR3++(1) 

;  Save  32-bit  data  in  internal  RAM 

LDI    @dp_mem,AR4 

;  Reset  AR4 

LDI    @blkl,AR3 

;  Reset  AR3 

LDI    *+AR3(tms_swf),Rl 

LDI    @swp_const,RO 

;  Determine  switching  period 

121 


CALL  divi 

STI    R0,*+AR3(tms_swp) 

LDI    02H,R1 

CALL  divi 

ADDI   10H,R0 

STI    R0,*+AR3(tms_swp_120) 

LDI    *+AR3(tms_swp),R0 

LDI    R0,R1 

LSH    -1H,R0 

STI    R0,*+AR3(tms_ta) 

LDI    *+AR3(tms_dt),R0 

LSH    01H,R0 

SUBI  R0,R1 

LSH    -1H,R1 

FLOAT  Rl 

RND    Rl 

STF    Rl,*+AR3(tms_tb) 

LDI    *+AR3(tms_of),R0 

LDI    *+AR3(tms_blk),Rl 

MPYI  R1,R0 

LDI    *+AR3(tms_swf),Rl 

CALL  divi 

STI    R0,*+AR3(tms_stepx) ; 

LDI    *+AR3(tms_btime),Rl 

STI     Rl,*+AR3(tms_tboost) 

LDI    *+AR3(tms_oaci),R2  ; 

FLOAT  R2 

STF    R2,*+AR3(tms_ilmin) 

RETS 
*(NSWC  code) 
init_swct:LDI  @ct_swfreg,ARO 

LDI  *+AR3(tms_swp),R0 

STI  R0,*+AR0(0) 

LSH  -08H,R0 

STI  R0,*+AR0(0) 

NOP 

NOP 

NOP 

LDI  *+AR3(tms_swp_120),R2 
checkoutO:LDI  0000H,R0 

STI  R0,*+AR0(3) 

LDI  *+AR0(0),R0 

AND  000FFH,R0 

LDI  *+AR0(0),Rl 


Determine  ta 


;  Determine  tb 


Determine  stepx 


Pointer  for  switching  frequency  timer  1 
Store  LSB  of  counter  0 
Store  MSB  of  counter  0 


Latch  command 


Clear  all  other  higher  bits 
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LSH  0008H,R1 
AND  00fD0H,Rl 
OR    R1,R0 
CMPI  R2,R0 
BGT  checkoutO 
LDI  *+AR3(tms_swp),R0    ; 
STI  R0,*+AR0(1) 
LSH  -0008H,R0 
STI  R0,*+AR0(1) 
NOP 
NOP 
NOP 

LDI  *+AR3(tms_swp_120),R2; 
checkoutLLDI  0040H,R0  ; 

STI  R0,*+AR0(3) 
LDI  *+AR0(l),R0 
AND  000FFH,R0 
LDI  *+AR0(l),Rl 
LSH  0008H,R1 
AND  OOfOOH,Rl 
OR    R1,R0 
CMPI  R2,R0 
BGT  checkout  1 
LDI  *+AR3(tms_swp),R0    ; 
STI  R0,*+AR0(2) 
LSH  -0008H,R0 
STI  R0,*+AR0(2) 


Store  LSB  of  counter  1 


Store  MSB  of  counter  1 


Latch  command 


Clear  all  other  higher  bits 


Store  LSB  of  counter  2 


Store  MSB  of  counter  2 


LDI  @ct_phasea,AR.O 

LDI  *+AR3(tms_btime),Rl ; 

STI  R1,*+AR0(0) 

LDI  *+AR3(tms_bdly),Rl   ; 

ADDI  *+AR3(tms_btime),Rl 

STI  R1,*+AR0(1) 

LDI  *+AR3(tms_ta),Rl 

STI  R1,*+AR0(2) 

LSH  -08H,R1 

STI  R1,*+AR0(2) 

LDI  @ct_phaseb,ARO 
LDI  *+AR3(tms_btime),Rl ; 
STI  R1,*+AR0(0) 
LDI  *+AR3(tms_bdly),Rl   ; 
ADDI  *+AR3(tms_btime),Rl 


;  Pointer  for  phase  a  counter 
;  Store  LSB  of  counter  0 

Store  LSB  of  counter  1 

Store  LSB  of  counter  2 

;  Store  MSB  of  counter  2 

;  Pointer  for  phase  b  counter 

;  Store  LSB  of  counter  0 
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STI  R1,*+AR0(1) 
LDI  *+AR3(tms_ta),Rl 
STI  R1,*+AR0(2) 
LSH  -08H,R1 
STI  R1,*+AR0(2) 

LDI  @ct_phasec,ARO 

LDI  *+AR3(tms_btime),Rl ; 

STI  R1,*+AR0(0) 

LDI  *+AR3(tms_bdly),Rl    ; 

ADDI  *+AR3(tms_btime),Rl 

STI  R1,*+AR0(1) 

LDI  *+AR3(tms_ta),Rl; 

STI  R1,*+AR0(2) 

LSH  -08H,R1 

STI  R1,*+AR0(2) 

LDI    *+AR3(tms_btime),R0 

STI     R0,*+AR3(tms_tboost); 

RETS 
*(NSWC  code)  Modified  25  Feb  97 
isrmode:  LDI    *+AR3(tms_mode),R0 

LDI    @mode_ad,Rl 

ADDI  R1,R0 

BNZ    RO 

RETS 


Store  LSB  of  counter  1 
Store  LSB  of  counter  2 
Store  MSB  of  counter  2 
Pointer  for  phase  c  counter 
Store  LSB  of  counter  0 

Store  LSB  of  counter  1 
Store  LSB  of  counter  2 
Store  MSB  of  counter  2 


modecmd:  BR     modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  modeO 

BR  mode  10 

BR  modeO 

BR  modeO 


;Stop 


;  DC  to  DC  Buck  Mode 


modeO:  LDI    08H,IE 

LDI    @ct_port,AR0 
LDI    @clear_main,R0 
STI    R0,*ARO 


Disable  interrupts  0,1,2 

Pointer  for  counter/timer  control  register 

Disable  all  output 


124 


LDI    030RR0 
wait30:    SUBI  01H,RO 
BNZ    wait30 
LDI    @reset_out,RO 
STI    RO,*ARO 
AND    08H,IF 
LDI    OOH,RO 
STI    R0,*+AR4(1) 
LDI    @dp_int,IRO 
STI    R0,*+AR4(IR0) 
RETS  ; 


Disable  all  counter/timer  output 
Clear  all  pending  interrupts  0,1,2 


Return 


*  DC  to  DC  Buck  Converter 

*(NPS  code)  5  May  97 

mode  10:  LDF  *+AR3(tms_Vref),R0 

LDF  *+AR3(Vin_inv),Rl 

LDF  *+AR3(Vout),R2 

LDF  *+AR3(Vdiff),R3 

LDF  *+AR3(iL),R6 

SUBF  *+AR3(iout),R6 

MPYF  *+AR3(hi),R6 

MPYF3  R0,R1,R4 

SUBF3  R0,R2,R5 

ADDF  R5,R3 

MPYF  *+AR3(hn),R3 
[Vdiff(n)+Vdiff(n-1)] 

ADDF  *+AR3(Vd_int),R3 

SUBF  R3,R4 

SUBF  R6,R4 

LDF 

MPYF  R5,R6 

SUBF  R6,R4 

LDI 

FLOAT 

MPYF  R7,R4 

SUBF  R4,R7 

CMPF  *+AR3(UMAX),R7 

BLE  LOW 

LDF  *+AR3(UMAX),R7 

LOW:  CMPF  *+AR3(UMIN),R7  ; 

BGT  SAME 

LDF  *+AR3(UMIN),R7 

SAME:  FIX  R7 

RETS 


RO=Vref 

Rl=  1/Vin 

R2=  Vout 

*R3=Vdiff(n-l) 

R6  =  iL 

R6  =  iL-iout 

R6  =  hi(iL-iout) 

R4=  Dss=Vref/Vin 

R5=  Vdiff(n)  =Vout-Vref 

*R3=  Vdiff(n)+Vdiff(n-1) 

*R3=Vd  int=KcT/2 


*R3=  Vd_int(n)  -  Vdint  +  Vdint(n-l) 
;R4=  D=Dss-Vd_int 
;R4  -  Dss  -  Vdint  -  hi(iL-iout) 
;R6  =  hv 

;R6  -  hv(Vout-Vref) 
R4  =  Dss  -  Vdint  -  hi(iL-iout)  -  hv(Vout-Vref) 
*+AR3(tms_swp),R7  ; 
R7  : 


*+AR3(hv),R6 


Return 
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*  (NSWC  code) 
timeO:  PUSH  RO 

PUSHF  RO 

PUSH  ARO 

LDI  *+AR3(tms_stepx),R0 

ADDI  01H,R0 

STI  R0,*+AR3(tms_stepx) 

CMPI  *+AR3(stopfreq),R0 
BLE  looptimerO 

LDI  000H,R0 

LDI  @ctrl,AR0 

STI  R0,*+AR0(20H)  ;  Clear  counter 

ANDN  masktimerOJE  ;  Disable  timer  interrupt 

POP  ARO 

POPF  RO 
POP  RO 

RETI 
looptimerO:  LDF  *+AR3(vperfreq),R0 

ADDF  *+AR3(tms_Vref),R0 

RND  RO 

STF  R0,*+AR3(tms_Vref) 

POP  ARO 

POPF  RO 

POP  RO 

RETI 

*  isrO:  Phase  a  interrupt  service  rountine 
*(NPS  code)  5  May  97 

isrO:    PUSH     ST  ;  Save  registers 

PUSH  IR1 
PUSH  R7 
PUSHF  R7 

PUSH  R6 
PUSHF  R6 

PUSH  R5 
PUSHF  R5 

PUSH  R4 
PUSHF  R4 

PUSH  R3 
PUSHF  R3 

PUSH  R2 
PUSHF  R2 

PUSH  Rl 
PUSHF  Rl 
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PUSH  RO 

PUSHF 

RO 

PUSH  ARO 

LDI 

@bcs,ARO 

LDI 

@ccs,AR2 

LDI 

*ARO,RO 

LDI 

*AR2,R1 

LDI 

00cH,R2 

01H,R2 

BNZ 

wait 

wait:     SUBI 


*  STORE  SAMPLED  VOLTAGES  AND  CURRENTS 


LDI 

*AR0,R0 

LDI 

*AR2,R2 

LDI 

R0,R1 

LSH 

04H,R1 

ASH 

-14H.R1 

FLOAT 

Rl 

LSH 

14H,R0 

ASH 

-14H,R0 

FLOAT 

RO 

LDI 

R2,R3 

LSH 

04H,R3 

ASH 

-14H,R3 

FLOAT 

R3 

LSH 

14H,R2 

ASH 

-14H,R2 

FLOAT 

R2 

LDI 

009H,R7 

waitl: 

SUBI    01H,R7 

BNZ 

waitl 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H,R4 

FLOAT 

R4 

LDI 

R6,R7 

LSH 

04H,R7 

ASH 

-14H,R7 

;  Pointer  for  DC  ADC 


;  initiat  conversion 


;  READ  Vin  AND  iL 
;  Rl  -  iL 


;  Getting  Vin  (J7) 
;  RO  =  Vin 


R3  -  iout 


;  Getting  Vout  (J  1) 
;  R2  =  Vout 


;  READ  Vin  AND  iL 
;  R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


;  R7  =  iout 
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FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14H,R6 

FLOAT 

R6 

ADDF  R4,R0 

ADDF  R5,R1 

ADDF  R6,R2 

ADDF  R7,R3 

LDI 

009H,R7 

wait2: 

SUBI    01H,R7 

BNZ 

wait2 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H.R4 

FLOAT 

R4 

LDI 

R6,R7 

LSH 

04H,R7 

ASH 

-14H,R7 

FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14H,R6 

FLOAT 

R6 

ADDF  R4,R0 

ADDF  R5,R1 

ADDF  R6,R2 

ADDF  R7,R3 

LDI 

009H,R7 

wait3 : 

SUBI    01H,R7 

BNZ 

wait3 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H,R4 

FLOAT 

R4 

LDI 

R6,R7 

;  Getting  Vout  (J  1) 
;  R6  =  Vout 

R0  =  Vin  (2) 
Rl  =  iL    (2) 
R2  =  Vout  (2) 
R3  =  iout  (2) 


;  READ  Vin  AND  iL 


;  R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


;  R7  =  iout 


;  Getting  Vout  (J  1) 
;  R6  =  Vout 

R0  =  Vin  (3) 
Rl  =  iL    (3) 
R2  =  Vout  (3) 
R3  =  iout  (3) 


;  READ  Vin  AND  iL 


;  R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 
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LSH 

04H,R7 

ASH 

-14H,R7 

FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14RR6 

FLOAT 

R6 

ADDF  R4,R0 

ADDF  R5,R1 

ADDF  R6,R2 

ADDF  R7,R3 

LDI 

009H,R7 

wait4:  SUBI    01H,R7 

BNZ 

wait4 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H,R4 

FLOAT 

R4 

LDI 

R6,R7 

LSH 

04H,R7 

ASH 

-14H,R7 

FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14H,R6 

FLOAT 

R6 

ADDF  R4,R0 

ADDF  R5,R1 

ADDF  R6,R2 

ADDF  R7,R3 

MPYF  @AVE,R1 

MPYF  *+AR3(tms_acscale),Rl 

RND 

Rl 

STF 

Rl,*+AR3(iL) 

CURRENT  iL 

MPYF  @AVE,R3 

MPYF  *+AR3(tms_acscale),R3 

RND 

R3 

STF 

R3,*+AR3(iout) 

CURRENT  iout 

MPYF  @AVE,R2 
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R7  =  iout 


;  Getting  Vout(Jl) 
;  R6  =  Vout 

RO  =  Vin  (4) 
Rl  =  iL    (4) 
R2  =  Vout  (4) 
R3  =  iout  (4) 


;  READ  Vin  AND  iL 


;  R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


;  R7  =  iout 


;  Getting  Vout  (J  1) 
;  R6  =  Vout 

R0  =  Vin  (5) 
Rl  =  iL    (5) 
R2  =  Vout  (5) 
R3  =  iout  (5) 


STORE  THE  INDUCTOR 


;  STORE  THE  OUTPUT 


Vout 


MPYF  *+AR3(tms_dcscale),R2 

RND  R2 

STF  R2,*+AR3(Vout) 

MPYF  @AVE,R0 

MPYF  *+AR3(tms_dcscale),R0 

CALL  FPINV 

RND  RO 

STF  R0,*+AR3(Vin_inv) 

LDF  *+AR3(Vdiffb),R0 

STF  R0,*+AR3(Vdiff) 

LDF  *+AR3(Vd_intb),R0 

STF  R0,*+AR3(Vd_int) 

CALL  isr  mode 


;  STORE  Output  voltage 


STORE  1/Vin 


LDI 

@ct_phaseb,ARO 

;  Pointer  for  phase  a  counter 

STI 

R7,*+AR0(2) 

;  Store  LSB  of  counter  2 

LSH 

-08H,R7 

? 

STI 

R7,*+AR0(2) 

;  Store  MSB  of  counter  2 

RND 

R5 

STF 

R5,*+AR3(Vdiffb) 

RND 

R3 

STF 

R3,*+AR3(Vd_intb) 

ANDN 

mask 

_intO,IF 

;  Clear  interrupt  0 

POP 

ARO 

POPF 

RO 

POP 

RO 

POPF 

Rl 

POP 

Rl 

POPF 

R2 

POP 

R2 

POPF 

R3 

POP 

R3 

POPF 

R4 

POP 

R4 

POPF 

R5 

POP 

R5 

POPF 

R6 

POP 

R6 

POPF 

R7 

POP 

R7 

POP 

IR1 

POP 

ST 

RETI 

;  Return  and  enable  interrup 
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*  isrl :  Phase  B  interrupt  service  rountine 
*(NPS  code)  5  May  97 


isrl:    PUSH    ST 

;  Save  registers 

PUSH  IR1 

PUSH  R7 

PUSHF 

R7 

PUSH  R6 

PUSHF 

R6 

PUSH  R5 

PUSHF 

R5 

PUSH  R4 

PUSHF 

R4 

PUSH  R3 

PUSHF 

R3 

PUSH  R2 

PUSHF 

R2 

PUSH  Rl 

PUSHF 

Rl 

PUSH  RO 

PUSHF 

RO 

PUSH  ARO 

* 

LDI 

@inputcs,ARO             ;  Poii 

LDI 

@acs,AR2 

LDI 

*AR0,R0 

LDI 

*AR2,R1 

LDI 

00cH,R2 

wait5:  SUBI    01H,R2 

BNZ 

wait5 

;  Pointer  for  DC  ADC 


;  initiat  conversion 


*  STORE  SAMPLED  VOLTAGES  AND  CURRENTS 


LDI 

*AR0,R0 

LDI 

*AR2,R2 

LDI 

R0,R1 

LSH 

04H,R1 

ASH 

-14H,R1 

FLOAT 

Rl 

LSH 

14H,R0 

ASH 

-14HJR0 

FLOAT 

RO 

LDI 

R2,R3 

;  READ  Vin  AND  iL 


;  Rl  =  iL 


;  Getting  Vin  (J7) 
;  RO  =  Vin 
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wait6:  SUBI 


wait7:  SUBI 


LSH 

04H,R3 

ASH 

-14H,R3 

FLOAT 

R3 

LSH 

14H,R2 

ASH 

-14H,R2 

FLOAT 

R2 

LDI 

009H,R7 

01H,R7 

BNZ 

wait6 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H,R4 

FLOAT 

R4 

LDI 

R6,R7 

LSH 

04H,R7 

ASH 

-14H,R7 

FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14H,R6 

FLOAT 

R6 

ADDF  R4,RC 

i 

ADDF  R5,R1 

ADDF  R6,R2 

i 

ADDF  R7,R3 

i 

LDI 

009H,R7 

01H,R7 

BNZ 

wait7 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H,R4 

FLOAT 

R4 

LDI 

R6,R7 

LSH 

04H,R7 

ASH 

-14H,R7 

;  R3  =  iout 


;  Getting  Vout  (J  1) 
:  R2  =  Vout 


READ  Vin  AND  iL 


R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


R7  -  iout 


;  Getting  Vout  (J  1) 
;  R6  =  Vout 


;  RO  =  Vin  (2) 
;  Rl  =  iL    (2) 
;  R2  =  Vout  (2) 
;  R3  =  iout  (2) 


;  READ  Vin  AND  iL 


R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


;  R7  -  iout 
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FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14H,R6 

FLOAT 

R6 

ADDF  R4,R0 

ADDF  R5,R1 

ADDF  R6,R2 

ADDF  R7,R3 

LDI 

009H,R7 

wait8: 

SUBI    01H,R7 

BNZ 

wait8 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14RR5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H,R4 

FLOAT 

R4 

LDI 

R6,R7 

LSH 

04H,R7 

ASH 

-14H,R7 

FLOAT 

R7 

LSH 

14H,R6 

ASH 

-14H,R6 

FLOAT 

R6 

ADDF  R4,R0 

ADDF  R5,R1 

ADDF  R6,R2 

ADDF  R7,R3 

LDI 

009H,R7 

wait9: 

SUBI    01H,R7 

BNZ 

wait9 

LDI 

*AR0,R4 

LDI 

*AR2,R6 

LDI 

R4,R5 

LSH 

04H,R5 

ASH 

-14H,R5 

FLOAT 

R5 

LSH 

14H,R4 

ASH 

-14H.R4 

FLOAT 

R4 

LDI 

R6,R7 

;  Getting  Vout  (J  1) 
;  R6  =  Vout 


R0  =  Vin  (3) 
Rl  =  iL    (3) 
R2  =  Vout  (3) 
R3  =  iout  (3) 


;  READ  Vin  AND  iL 


;  R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


;  R7  =  iout 


;  Getting  Vout  (Jl) 
;  R6  =  Vout 


R0  =  Vin  (4) 
Rl  =  iL    (4) 
R2  =  Vout  (4) 
R3  =  iout  (4) 


;  READ  Vin  AND  iL 


;  R5  =  iL 


;  Getting  Vin  (J7) 
;  R4  =  Vin 


133 


LSH                 04H,R7 

;  R7  =  iout 

ASH                -14H,R7 

FLOAT            R7 

LSH                 14H,R6 

;  Getting  Vout  (J  1) 

ASH                -14H,R6 

;  R6  =  Vout 

FLOAT            R6 

ADDF  R4,R0 

R0  = 

=  Vin  (5) 

ADDF  R5,R1 

Rl  = 

-\L    (5) 

ADDF  R6,R2 

,R2  = 

=  Vout  (5) 

ADDF  R7,R3 

,R3  = 

=  iout  (5) 

MPYF  @AVE,R1 

MPYF  *+AR3(tms_acscale),Rl 

RND                Rl 

STF                  Rl,*+AR3(iL) 

.STORE!  IE  INDUCTOR 

CURRENT  iL 

MPYF  @AVE,R3 

MPYF  *+AR3(tms_acscale),R3 

RND               R3  ' 

STF                 R3,*+AR3(iout) 

;  STORE  THE  OUTPUT 

CURRENT  iout 

MPYF  @AVE,R2 

MPYF  *+AR3(tms  dcscale),R2 

RND                R2 

i 

STF                 R2,*+AR3(Vout) 

;  STORE  Output  voltage 

Vout 


MPYF  @AVE,R0 

MPYF  *+AR3(tms_dcscale),R0 

CALL  FPINV  ; 

RND  RO  ; 

STF  R0,*+AR3(Vin_inv)    ;  STORE  1/Vin 

LDF  *+AR3(Vdiffa),R0 

STF  R0,*+AR3(Vdiff) 

LDF  *+AR3(Vd_inta),R0 

STF  R0,*+AR3(Vd_int) 

CALL  isr  mode 


LDI 

@ct_phasea,ARO 

STI 

R7,*+AR0(2) 

LSH 

-08H,R7 

STI 

R7,*+AR0(2) 

RND 

R5 

STF 

R5,*+AR3(Vdiffa) 

RND 

R3 

STF 

R3,*+AR3(Vd  inta) 

Pointer  for  phase  a  counter 
Store  LSB  of  counter  2 

;  Store  MSB  of  counter  2 


ANDNmask  intl,IF 


;  Clear  interrupt  1 
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POP 

AR( 

POPF 

RO 

POP 

RO 

POPF 

Rl 

POP 

Rl 

POPF 

R2 

POP 

R2 

POPF 

R3 

POP 

R3 

POPF 

R4 

POP 

R4 

POPF 

R5 

POP 

R5 

POPF 

R6 

POP 

R6 

POPF 

R7 

POP 

R7 

POP 

IR1 

POP 

ST 

RETI  ;  Return  and  enable  interrupt 


*(NSWC  code) 

*  irs3 :  Dual  port  memory  interrupt  service  rountine 

isr3:    PUSH    ST  ;  Save  registers 

PUSH  DP 
PUSH  IR1 
PUSH  R7 
PUSHF  R7 

PUSH  R6 
PUSHF  R6 

PUSH  R5 
PUSHF  R5 

PUSH  R4 
PUSHF  R4 

PUSH  R3 
PUSHF  R3 

PUSH  R2 
PUSHF  R2 

PUSH  Rl 
PUSHF  Rl 
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PUSH  RO 
PUSHF 


RO 


LDI  @dp_cint,IRO 

LDI  *+AR4(IR0),R0 

CALL  readcmd 
ANDNmask  int3,IF 


Clear  interrupt 


;  Clear  interrupt  3 


POPF 
POP 

RO 

RO 

POPF 

Rl 

POP 

Rl 

POPF 

R2 

POP 

R2 

POPF 

R3 

POP 

R3 

POPF 

R4 

POP 

R4 

POPF 

R5 

POP 

R5 

POPF 

R6 

POP 

R6 

POPF 

R7 

POP 

R7 

POP 

IR1 

POP 

DP 

POP 

ST 

RETI 


Return  and  enable  interrupt 


.end 
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